题海拾贝: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;
}
相关推荐
TiAmo zhang1 分钟前
深度学习与图像处理 | 基于PaddlePaddle的梯度下降算法实现(线性回归投资预测)
图像处理·深度学习·算法
一匹电信狗16 分钟前
【C++】手搓一个STL风格的vector容器
c语言·数据结构·c++·算法·leetcode·stl·visual studio
生信探索21 分钟前
SeuratExtend 可视化教程(1):单细胞分析的高颜值绘图指南
算法
小小小白的编程日记28 分钟前
C语言中的数据结构--栈和队列(2)
c语言·数据结构
李永奉36 分钟前
C语言-数组:数组(定义、初始化、元素的访问、遍历)内存和内存地址、数组的查找算法和排序算法;
c语言·算法·排序算法
星辰大海的精灵1 小时前
深入解析 CopyOnWriteArrayList
java·后端·算法
重启的码农1 小时前
深入fecal实现 (6) 伽罗瓦域 GF(256) 运算
c++·网络协议
重启的码农1 小时前
深入fecal实现 (2) 编码器 (Encoder)
c++·网络协议
逝雪Yuki1 小时前
Leetcode——11. 盛最多水的容器
c++·算法·leetcode·双指针
找不到、了1 小时前
Java排序算法之<希尔排序>
java·算法·排序算法