1234.倍数问题
暴力思路(TLE,可以过5/11个数据)
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long LL;
const int N=1e5+10;
int a[N];
int n,k;
int main()
{
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++) scanf("%d",&a[i]);
sort(a,a+n);
LL maxd=-1;
for(int i=n-1;i>=2;i--)
{
for(int j=i-1;j>=1;j--)
{
for(int c=j-1;c>=0;c--)
{
LL sum=a[i]+a[j]+a[c];
if(sum%k==0)
{
maxd=max(maxd,sum);
}
}
}
}
cout<<maxd<<endl;
return 0;
}
DP做法:
#include<iostream>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
typedef long long LL;
const int N=1e5+10;
vector<int> a[N];
int f[4][N];
int n,m;
int main()
{
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++)
{
int x;
scanf("%d",&x);
a[x%m].push_back(x);
}
memset(f,-0x3f,sizeof f);
f[0][0]=0;
for(int i=0;i<m;i++)
{
sort(a[i].begin(),a[i].end());
reverse(a[i].begin(),a[i].end());
for(int u=0;u<3 && u<a[i].size();u++)
{
int x=a[i][u];
for(int j=3;j>=1;j--)
{
for(int k=0;k<m;k++)
{
f[j][k]=max(f[j][k],f[j-1][(k-x%m+m)%m]+x);
}
}
}
}
printf("%d\n",f[3][0]);
return 0;
}
原题链接弄错了吧
没有啊,刚刚修改了代码,现在应该只有超时的问题了