蓝桥杯1447 砝码称重

问题描述

你有一架天平和 N 个砝码,这 N 个砝码重量依次是 W1,W2,⋅⋅⋅,WN​。

请你计算一共可以称出多少种不同的重量? 注意砝码可以放在天平两边。

输入格式

输入的第一行包含一个整数 N。

第二行包含 N 个整数:W1,W2,W3,⋅⋅⋅,WN​。

输出格式

输出一个整数代表答案。

样例输入

复制代码
3
1 4 6

样例输出

复制代码
10

样例说明

能称出的 10 种重量是:1、2、3、4、5、6、7、9、10、11。

1=1;

2=6−4(天平一边放 6,另一边放 4);​

3=4−1;

4=4;

5=6−1;

6=6;

7=1+6;

9=4+6−1;

10=4+6;

11=1+4+6。

评测用例规模与约定

对于 50的评测用例,1≤N≤15。

对于所有评测用例,1≤N≤100,N1≤N≤100,N​个砝码总重不超过 100000。

cpp 复制代码
#include<iostream>
#include<cmath>
using namespace std;

const int N = 110;
const int M = 2e5+10;  //j的范围是 [-m, m],M为最大可能重量的两倍
int n;
int m;  //总重量
int w[N];
bool f[N][M];  //f[i][j]:前i个砝码能否称出重量j
int ans;

int main()
{
	cin>>n;
	for(int i=1; i<=n; ++i)
	{
		cin>>w[i];
		m += w[i];
	}
	
	f[0][0]=1;  //初始化:0个砝码称出0
	
	//枚举前i个砝码
	for(int i=1; i<=n; ++i)
	{
		//枚举所有可能的重量
		for(int j=0; j<=m; ++j)
		{
			//不选当前砝码 || 选砝码放到左盘 || 选砝码放到右盘
			f[i][j]=f[i-1][j] || f[i-1][abs(j-w[i])] || f[i-1][j+w[i]];
		}
	}
	
	for(int i=1; i<=m; ++i)
	{
		if(f[n][i]) ans++;
	}
	
	cout<<ans;
	
	return 0;
}
相关推荐
2401_8414956412 小时前
【强化学习】动态规划算法
人工智能·python·算法·动态规划·强化学习·策略迭代·价值迭代
天选之女wow2 天前
【代码随想录算法训练营——Day43(Day42周日休息)】动态规划——300.最长递增子序列、674.最长连续递增序列、718.最长重复子数组
算法·leetcode·动态规划
前端小L2 天前
动态规划的“数学之魂”:从DP推演到质因数分解——巧解「只有两个键的键盘」
算法·动态规划
2401_840105204 天前
P1049 装箱问题 题解(四种方法)附DP和DFS的对比
c++·算法·深度优先·动态规划
Mysticbinary4 天前
遗传算法入门
遗传算法·背包问题
Juan_20124 天前
P1040题解
c++·算法·动态规划·题解
Onesoft%J1ao4 天前
C++竞赛递推算法-斐波那契数列常见题型与例题详解
c++·算法·动态规划·递推·信息学奥赛
Brookty4 天前
【算法】前缀和
java·学习·算法·前缀和·动态规划
M17迪Pq:00075 天前
学会“做减法”之--用户体验优化
人工智能·贪心算法·产品运营·动态规划·软件工程
BanyeBirth5 天前
C++动态规划——LIS(最长不下降子序列)
算法·动态规划