第十二届蓝桥杯省赛C&C++ 研究生组-砝码称重


solution1(通过10%)

写了几种可能的组合方式,骗到一丢丢分数

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<map>
using namespace std;
int main(){
	int n, a[110], count = 0, sum[110] = {0};
	map<int, int> mp;
	scanf("%d", &n);
	for(int i = 0; i < n; i++){
		scanf("%d", a + i);
		if(i == 0) sum[i] = a[i];
		else sum[i] = a[i] + sum[i - 1];
		mp[a[i]] = 1;
		mp[sum[i]] = 1;
	} 
	sort(a, a + n); 
	for(int i = 1; i <= sum[n - 1]; i++){
		if(mp[i] == 1) continue;
		for(int j = n - 1; j >= 0; j --){
			for(int k = 0; k < j; k++){
				if(a[j] - a[k] == i){
					mp[i] = 1;
					continue;
				}
			}
		}
		if(!mp[i]){
			for(int j = n - 1; j>= 0; j--){
				for(int k = 0; k < j; k++){
					if(a[k] + a[j] == i){
						mp[i] = 1;
						continue;
					}
				}
			}
		}
	}
	printf("%d", mp.size());
	return 0;
}

solution2(动规)

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
const int maxn = 100010, N = 110;
int dp[N][maxn] = {0}, w[N];//dp[i][j]表示用前i个砝码,是否可以称出j克的重量 
int main(){
	int n, max = 0, count = 0;
	scanf("%d", &n);
	for(int i = 1; i <= n; i++){
		scanf("%d", w + i);
		max += w[i];
	}
	for(int i = 1; i <= n; i++){//依次计算前i个砝码能够称出的重量 
		for(int j = 1; j <= max; j++){//依次判断所有可能的重量是否能称出来 
			dp[i][j] = dp[i - 1][j];//用i个砝码能称出来的重量,i+1个肯定也能成
			if(dp[i][j] == 0){//i-1个不能称,看看加上第i个行不行
				//能称出的三种情况:1.刚好是第i个砝码本身重量  2.已经能称出来j+a[i],第i个拿到对面 3.已经能称出abs(j-a[i])加上第i个 
				if(w[i] == j || (dp[i - 1][j + w[i]]) || (dp[i-1][abs(j - w[i])])) dp[i][j] = 1; 
			} 
		}
	}
	for(int j = 1; j <= max; j++)
		count += dp[n][j];
	printf("%d", count);
	return 0;
}
相关推荐
CoderYanger5 小时前
C.滑动窗口-求子数组个数-越长越合法——2799. 统计完全子数组的数目
java·c语言·开发语言·数据结构·算法·leetcode·职场和发展
LinHenrY12276 小时前
初识C语言(自定义结构:结构体)
c语言·开发语言
cooldream20097 小时前
当代 C++ 的三大技术支柱:资源管理、泛型编程与模块化体系的成熟演进
开发语言·c++
程序员Jared7 小时前
深入浅出C语言——文件操作
c语言
Queenie_Charlie8 小时前
数字去重(set)
数据结构·c++·set
Ayanami_Reii8 小时前
区间不同数的个数-树状数组/线段树/莫队/主席树
数据结构·c++·算法·线段树·树状数组·主席树·莫队
大筒木老辈子9 小时前
C++笔记---并发支持库(atomic)
java·c++·笔记
zero_hz9 小时前
核心区分:用户态/内核态切换 vs. 程序阻塞
c++·io·内核态用户态
胡萝卜3.09 小时前
深入C++可调用对象:从function包装到bind参数适配的技术实现
开发语言·c++·人工智能·机器学习·bind·function·包装器
CoderYanger9 小时前
C.滑动窗口-求子数组个数-越长越合法——3325. 字符至少出现 K 次的子字符串 I
c语言·数据结构·算法·leetcode·职场和发展·哈希算法·散列表