AC自动机

[蓝桥杯 2021 省 AB] 砝码称重

题目描述:

你有一架天平和 N 个砝码, 这 N 个砝码重量依次是 W1, W2 .. ..WN 。 请你计算一共可以称出多少种不同的重量?

注意砝码可以放在天平两边。

思路:总共可选择的重量在1到总重之间。f[i][j] 表示在前i个砝码中重量为j.

可分为四种状态:

1.当 j==a[i] f[i][j]=1。

2.当f[i-1][j]==1 f[i][j]=1. 无需添加。

3.当 f[i-1][j+a[i]]==1 f[i][j]=1.可添加一个当前砝码。

4.当 f[i-1][j-a[i]]==1 f[i][j]=1.可减少一个当前砝码。

复制代码
#include <iostream>
using namespace std;
int a[110];
int f[110][100010];
int main()
{
	int n;
	cin>>n;
	int sum=0;
	for (int i=1;i<=n;i++){
		cin>>a[i];
		
		sum+=a[i];
	}
	
	for (int i=1;i<=n;i++){
		for (int j=sum;j;j--){
			if(j==a[i])f[i][j]=1;
			else if (f[i-1][j]==1)f[i][j]=1;
			else if (f[i-1][j+a[i]]==1)f[i][j]=1;
			else if (f[i-1][abs(j-a[i])]==1) f[i][j]=1;
		}
	}
	int ans=0;
    
	for (int i=1;i<=sum;i++){
		if(f[n][i]==1){
			ans++;
		}
	}

	cout<<ans;
	
	
}
相关推荐
xy34539 天前
软件评测师基础知识专项刷题:信息系统生命周期(一)
刷题·软考·备考·软件设计师·软件评测师
王老师青少年编程10 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:糖果传递
c++·刷题·贪心·csp·信奥赛·线性扫描贪心·糖果传递
xy345322 天前
软件评测师基础知识专项刷题:编译、解释、汇编(1)
刷题·软考·编译·备考·软件设计师·软件评测师
李日灐1 个月前
【优选算法1】双指针经典算法题
数据结构·c++·后端·算法·刷题·双指针
锅包一切2 个月前
PART7 队列
c++·学习·算法·leetcode·力扣·刷题·队列
锅包一切2 个月前
PART17 一维动态规划
c++·学习·算法·leetcode·动态规划·力扣·刷题
烟花落o2 个月前
【数据结构系列03】链表的回文解构、相交链表
数据结构·算法·链表·刷题
烟花落o2 个月前
【数据结构系列02】轮转数组、返回倒数第k个节点
数据结构·算法·leetcode·刷题
烟花落o2 个月前
【数据结构系列01】时间复杂度和空间复杂度:消失的数字
数据结构·算法·leetcode·刷题
0和1的舞者3 个月前
力扣hot100-链表专题-刷题笔记(一)
数据结构·链表·面试·刷题·知识