社区讨论

55分求助

P1282多米诺骨牌参与者 1已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@lo8q3lo5
此快照首次捕获于
2023/10/27 22:43
2 年前
此快照最后确认于
2023/10/27 22:43
2 年前
查看原帖
CPP
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=1e3+10;
int a[N],b[N];
int f[N][N*6];
int n;
int s[N];
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++){cin>>a[i]>>b[i];s[i]=s[i-1]+a[i]+b[i];}
    memset(f,100,sizeof f);
    f[0][0]=0;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=s[i];j++){
            f[i][j]=min(f[i-1][j-a[i]],f[i-1][j-b[i]]+1);
        }
    }
    int ans=1e9,sum=1e9;
    for(int i=1;i<=s[n];i++){
        if(f[n][i]<=1000000){
            if(abs(s[n]-i-i)<sum){
                sum=abs(s[n]-i-i);
                ans=f[n][i];    
            }
            if(abs(s[n]-i-i)==sum)ans=min(ans,f[n][i]);
        }
    }
    cout<<ans;
}

回复

1 条回复,欢迎继续交流。

正在加载回复...