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;
	
	
}
相关推荐
想你时风起9 天前
力扣题库第一题:两数之和
python·力扣·刷题·两数之和
幼儿园口算大王19 天前
最简单的难题——游戏英雄升级潜力评估
java·算法·刷题
小殷要努力刷题!2 个月前
每日一刷——1.20——准备蓝桥杯
java·学习·算法·蓝桥杯·刷题·牛客·语法学习
L~river2 个月前
SQL刷题快速入门(三)
数据库·sql·mysql·笔试·刷题
丷从心2 个月前
【刷题】【力扣】【180】【中等】连续出现的数字
力扣·刷题
L~river2 个月前
SQL刷题快速入门(二)
数据库·sql·mysql·算法·笔试·刷题
L~river2 个月前
SQL刷题快速入门(一)
数据库·sql·oracle·笔试·刷题
mafucan2 个月前
VulnHub-Acid(1/100)
linux·安全·渗透测试·靶场·刷题·vulnhub
邂逅岁月2 个月前
滑不动窗口的秘密—— “滑动窗口“算法 (Java版)
算法·面试·求职招聘·创业创新·刷题
misty youth4 个月前
15-7数字字符串格式化
python·算法·刷题·python刷题