题海拾贝:P2347 [NOIP 1996 提高组] 砝码称重

Hello大家好!很高兴我们又见面啦!给生活添点passion,开始今天的编程之路!

我的博客: <但凡.

我的专栏: 《编程之路》《数据结构与算法之美》《题海拾贝》《C++修炼之路》

欢迎点赞,关注!

1、题目

2、题解

cpp 复制代码
#include<iostream>
using namespace std;
const int N = 1010;
int f[N];
int u[10] = { 0,1,2,3,5,10,20 };
int k[10];
int n, m;
int ret = 0;
int main()
{
	for (int i = 1;i <= 6;i++)
	{
		cin >> k[i];
		ret += k[i] * u[i];
	}
	int sum = 0;
	f[0] = 1;//对0初始化
	for (int i = 1;i <= 6;i++)
	{
		for (int j = ret;j >= 0;j--)//因为j是价值所以说j必须是从0开始
		{
			for (int p = 0;p <= k[i] && p * u[i] <= j;p++)
			{
				f[j] = f[j]||f[j - p * u[i]];//哪个不为0就选哪个行了
			}
		}
	}
	//f表示的是从前i个挑选,能否凑成j。所以说最后得统计方案数
	//另外我们砝码必须都选,也就是必须选6个,所以这个题可以空间优化写
	for (int i = 1;i <= 1000;i++)
	{
		if (f[i]) sum++;
	}
	cout <<"Total=" <<sum << endl;
	return 0;
}
相关推荐
chao1898444 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙4 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
難釋懷4 小时前
Redis数据结构-Set结构
数据结构·redis·bootstrap
little~钰4 小时前
倍增算法和ST表
算法
知识领航员5 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪5 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声6 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠6 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
ECT-OS-JiuHuaShan7 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算