包子凑数(蓝桥杯17H)————动态规划+二分查找

cpp 复制代码
#include<iostream>
using namespace std;
int gcd(int a,int b) {
	int tmp;
	if (a<b) {
		tmp = a;
		a = b;
		b = tmp;
	}
	return b == 0 ? a : gcd(b,a%b);
}
int main() {
	int dp[10001],n;
	memset(dp,0,sizeof(dp));
	cin >> n;
	int* a = new int[n];
	int g,maxn = 0;
	for (int i = 0; i < n;i++) {
		cin >> a[i];
		if (i == 0) {
			g = a[i];
		}
		else {
			g = gcd(g,a[i]);
		}
		maxn = max(maxn, a[i]);
	}
	if (g != 1) {
		cout << "INF";
		return 1;
	}
	dp[0] = 1;
	for (int i = 0; i < n;i++) {
		for (int j = a[i]; j < 10001;j++) {
			dp[j] = (dp[j]>0||dp[j-a[i]]>0)?1:0;
		}
	}
	for (int i = 10001/2; i>0;i/=2) {
		int cnt = 0;
		for (int j = i; j > i - maxn;j--) {
			if (dp[j] == 1) {
				cnt++;
			}
		}
		if (cnt != maxn) {
			int ans = 0;
			for (int z = 1; z <= i * 2;z++) {
				if (!dp[z]) {
					ans++;
				}
			}
			cout << ans;
			return 0;
		}
	}
	return 0;
}
相关推荐
灰灰勇闯IT8 分钟前
ops-reduce:ReduceMax 与 ReduceMean 的并行优化
算法
水木流年追梦17 分钟前
大模型入门-Reward 奖励模型训练
开发语言·python·算法·leetcode·正则表达式
沙威玛_LHE27 分钟前
P13376题解
算法
DFT计算杂谈1 小时前
KPROJ编译教程
java·前端·python·算法·conda
重生之我是Java开发战士1 小时前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数
java·算法·动态规划
吃好睡好便好2 小时前
用if…end…语句计算分段函数
开发语言·人工智能·学习·算法·matlab
灰灰勇闯IT2 小时前
ops-memory:CANN Runtime 的 Tensor 内存管理
算法
叶子Talk3 小时前
OpenAI破解80年数学猜想,AI首次做出原创证明
人工智能·数学·算法·机器学习·ai·openai·ai推理
MhZhou04123 小时前
1.11M参数小模型实现脑瘤分割 CVPR 2026 Findings 开源
算法·计算机视觉·3d·空间计算
有为少年3 小时前
Welford算法 | 从单一到批次
大数据·人工智能·深度学习·神经网络·算法·机器学习