解题思路:

用二进制数的每一位来代表是否选用该张邮票,1为选用,0为不选用,前四位代表价值为3,后三位代表价值为5的邮票,将二进制0000001(0x01)遍历至1111111(0x7f)即可得到所有选择,在每次选择中记录该选择的和,使用set容器查看该数是否被记录过,若没有记录过则将其插入set,否则继续循环,最后输出set容器大小即可得到所有组合方案。


参考代码:

#include #include using namespace std;

int main()
{
	set res;
	for (int choice = 0x01; choice <= 0x7f; choice++) {
		int tmp = choice;
		int sum = 0;
		for (int i = 0; i < 7; i++) {
			if (i < 4) {
				sum += 3 * (tmp % 2);
			}
			else {
				sum += 5 * (tmp % 2);
			}
			tmp >>= 1;
		}
		if (res.find(sum) == res.end())
			res.insert(sum);
	}
	cout << res.size();
	return 0;
}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论