标签:sort Ball int maxn BerSU using solve INPUT
题目链接:https://codeforces.com/problemset/problem/489/B
动态规划解法:思路和LCS一致
#include<bits/stdc++.h> using namespace std; const int maxn=110; int a[maxn]; int b[maxn]; int dp[maxn][maxn]; int n,m; void solve(){ sort(a+1,a+1+n); sort(b+1,b+1+m); for(int i=1;i<=n;i++){ for(int j=1;j<=m;j++){ if(abs(a[i]-b[j])==1 || a[i]==b[j]){ dp[i][j]=max(dp[i][j],dp[i-1][j-1]+1); }else{ dp[i][j]=max(dp[i][j],max(dp[i-1][j],dp[i][j-1])); } } } printf("%d",dp[n][m]); return ; } void INPUT(){ scanf("%d",&n); for(int i=1;i<=n;i++){ cin>>a[i]; } scanf("%d",&m); for(int i=1;i<=m;i++){ cin>>b[i]; } } int main() { INPUT(); solve(); return 0; }
双指针解法:
#include<bits/stdc++.h> using namespace std; const int maxn=1e5+10; int a[maxn]; int b[maxn]; bool vis[maxn]; bool vis2[maxn]; double ans; int n,m; void solve(){ int cnt=0; int j=0; sort(a,a+n); sort(b,b+m); int l=0,r=0; while(l<n&&r<m){ if(abs(a[l]-b[r])==1||a[l]==b[r]){ l++; r++; cnt++; continue; } if(a[l]<b[r]-1){ l++; }else{ r++; } } printf("%d",cnt); return ; } void INPUT(){ scanf("%d",&n); for(int i=0;i<n;i++){ cin>>a[i]; } scanf("%d",&m); for(int i=0;i<m;i++){ cin>>b[i]; } } int main() { INPUT(); solve(); return 0; }
标签:sort,Ball,int,maxn,BerSU,using,solve,INPUT 来源: https://www.cnblogs.com/Zangyh/p/15725417.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。