文章目录
- [HJ108 求最小公倍数](#HJ108 求最小公倍数)
- [NC95 数组中的最长连续子序列](#NC95 数组中的最长连续子序列)
- [DP39 字母收集](#DP39 字母收集)
HJ108 求最小公倍数
cpp
#include<iostream>
using namespace std;
int a,b;
int gcd(int a,int b)
{
if(b==0) return a;
return gcd(b,a%b);
}
int main()
{
cin>>a>>b;
int t=gcd(a,b);
int ans=a*b/t;
cout<<ans<<endl;
return 0;
}
NC95 数组中的最长连续子序列
cpp
class Solution {
public:
int MLS(vector<int>& arr) {
int n=arr.size();
sort(arr.begin(),arr.end());
int ans=0;
for(int i=0;i<n;)
{
int j=i+1,cnt=1;
while(j<n)
{
if(arr[j]-arr[j-1]==1)
{
cnt++;
j++;
}
else if(arr[j]-arr[j-1]==0) j++;
else break;
}
ans=max(cnt,ans);
i=j;
}
return ans;
}
};
DP39 字母收集
cpp
#include<iostream>
using namespace std;
const int N=505;
int m,n;
char g[N][N];
int dp[N][N];
int main()
{
cin>>m>>n;
for(int i=0;i<m;i++)
{
for(int j=0;j<n;j++)
{
cin>>g[i][j];
}
}
for(int i=0;i<=m;i++)
{
for(int j=0;j<=n;j++)
{
int t=0;
if(g[i][j]=='l') t=4;
else if(g[i][j]=='o') t=3;
else if(g[i][j]=='v') t=2;
else if(g[i][j]=='e') t=1;
dp[i][j]=max(dp[i][j-1],dp[i-1][j])+t;
}
}
cout<<dp[m][n]<<endl;
return 0;
}