Acwing2024蓝桥杯背包问题

AcWing 2. 01背包问题

cpp 复制代码
#include<iostream>
using namespace std;
const int N=1e3+5;
int n,m,volume[N],value[N],dp[N][N];
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++) cin>>volume[i]>>value[i];
    for(int i=1;i<=n;i++){
        for(int j=0;j<=m;j++){
            dp[i][j]=dp[i-1][j];
            if(j>=volume[i]) dp[i][j]=max(dp[i-1][j],dp[i-1][j-volume[i]]+value[i]);
        }
    }
    cout<<dp[n][m]<<endl;
    return 0;
}

AcWing 3. 完全背包问题

cpp 复制代码
#include<iostream>
using namespace std;
const int N=1e3+5;
int n,m,volume[N],value[N],dp[N][N];
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++) cin>>volume[i]>>value[i];
    for(int i=1;i<=n;i++){
        for(int j=0;j<=m;j++){
            dp[i][j]=dp[i-1][j];
            if(j>=volume[i]) dp[i][j]=max(dp[i-1][j],dp[i][j-volume[i]]+value[i]);
        }
    }
    cout<<dp[n][m]<<endl;
    return 0;
}

AcWing 1371. 货币系统

cpp 复制代码
#include<iostream>
using namespace std;
long long n,m,dp[30][10005],volume[30];
//dp[i][j]表示:只用前i种货币并且总钱数为j的所有方案数
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++) cin>>volume[i];
    for(int i=0;i<=n;i++) dp[i][0]=1;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            dp[i][j]=dp[i-1][j];
            if(j>=volume[i]) dp[i][j]+=dp[i][j-volume[i]];
        }
    }
    cout<<dp[n][m]<<endl;
    return 0;
}

AcWing 1226. 包子凑数(第八届省赛)

cpp 复制代码
裴蜀定理:
若a,b是整数,且gcd(a,b)=d
那么对于任意的整数x,y,(ax+by)都一定是d的倍数
cpp 复制代码
如果这些数的gcd是d
那么他们的组合是d的倍数
如果d不是1
那么必然有无限个数无法被组合出来
cpp 复制代码
#include<iostream>
using namespace std;
int n,volume[105],ans;
bool dp[105][10005];
//dp[i][j]:用前i个笼子是否可以组成j个数目的包子
//最大公约数:
int gcd(int a,int b){
    return b?gcd(b,a%b):a;
}
int main(){
    cin>>n;
    int temp=0;
    for(int i=1;i<=n;i++){
        cin>>volume[i];
        temp=gcd(temp,volume[i]);
    }
    if(temp!=1) {puts("INF");return 0;}
    dp[0][0]=true;
    for(int i=1;i<=n;i++){
        for(int j=0;j<=10005;j++){
            dp[i][j]=dp[i-1][j];
            if(!dp[i][j]&&j>=volume[i]){
                dp[i][j]=dp[i][j-volume[i]];
            }
        }
    }
    for(int j=0;j<=10005;j++) if(!dp[n][j]) ans++;
    cout<<ans<<endl;
    return 0;
}

AcWing 3417. 砝码称重(第十二届省赛)

cpp 复制代码
#include<iostream>
using namespace std;
int n,volume[105],sum,ans;
bool dp[105][200005];
//dp[i][j]:用前i个砝码是否可以组成j,注意这里的j要开两倍(有绝对值)
int main(){
    cin>>n;
    for(int i=1;i<=n;i++) cin>>volume[i],sum+=volume[i];
    dp[0][0]=true;
    for(int i=1;i<=n;i++){
        for(int j=0;j<=sum;j++){
            dp[i][j]=dp[i-1][j]||dp[i-1][j+volume[i]]||dp[i-1][abs(j-volume[i])];
        }
    }
    for(int i=1;i<=sum;i++) if(dp[n][i]) ans++;
    cout<<ans<<endl;
    return 0;
}

AcWing 1234. 倍数问题(第九届省赛)

暴力法(超时未AC 60points):

cpp 复制代码
#include<iostream>
using namespace std;
const int N=1e5+5;
int n,m,a[N],ans;
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++) cin>>a[i];
    for(int i=1;i<=n;i++)
        for(int j=i+1;j<=n;j++)
            for(int k=j+1;k<=n;k++)
                if((a[i]+a[j]+a[k])%m==0) ans=max(ans,a[i]+a[j]+a[k]);
    cout<<ans<<endl;
    return 0;
}
相关推荐
1 9 J21 分钟前
Java 上机实践4(类与对象)
java·开发语言·算法
passer__jw7672 小时前
【LeetCode】【算法】3. 无重复字符的最长子串
算法·leetcode
passer__jw7672 小时前
【LeetCode】【算法】21. 合并两个有序链表
算法·leetcode·链表
sweetheart7-72 小时前
LeetCode22. 括号生成(2024冬季每日一题 2)
算法·深度优先·力扣·dfs·左右括号匹配
李元豪3 小时前
【智鹿空间】c++实现了一个简单的链表数据结构 MyList,其中包含基本的 Get 和 Modify 操作,
数据结构·c++·链表
UestcXiye4 小时前
《TCP/IP网络编程》学习笔记 | Chapter 9:套接字的多种可选项
c++·计算机网络·ip·tcp
一丝晨光5 小时前
编译器、IDE对C/C++新标准的支持
c语言·开发语言·c++·ide·msvc·visual studio·gcc
景鹤5 小时前
【算法】递归+回溯+剪枝:78.子集
算法·机器学习·剪枝
_OLi_5 小时前
力扣 LeetCode 704. 二分查找(Day1:数组)
算法·leetcode·职场和发展
丶Darling.5 小时前
Day40 | 动态规划 :完全背包应用 组合总和IV(类比爬楼梯)
c++·算法·动态规划·记忆化搜索·回溯