包子凑数(蓝桥杯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;
}
相关推荐
ksbglllllll3 分钟前
ccfcsp3402矩阵重塑(其二)
数据结构·c++·算法
小馒头学python3 小时前
蓝耘智算|从静态到动态:探索Maas平台海螺AI图片生成视频功能的强大能力
人工智能·python·学习·算法·aigc
Q_Boom6 小时前
LeetCode 环形链表II:为什么双指针第二次会在环的入口相遇?
算法·leetcode·链表
SsummerC6 小时前
【leetcode100】括号生成
python·算法·leetcode
gotoc丶6 小时前
堆排序:力扣215.数组中的第K个大元素
javascript·数据结构·算法·leetcode·排序算法
一只_程序媛6 小时前
【leetcode hot 100 199】二叉树的右视图
算法·leetcode·职场和发展
一只_程序媛6 小时前
【leetcode hot 100 230】二叉搜索树中第K小的元素
算法·leetcode·职场和发展
双叶8368 小时前
(C语言)写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和(递归函数)
c语言·开发语言·数据结构·算法·游戏
BineHello8 小时前
强化学习 - PPO控制无人机
人工智能·算法·自动驾驶·动态规划·无人机·强化学习
阿饼2408 小时前
算法——层序遍历和中序遍历构造二叉树
数据结构·算法