原题链接:C语言训练-邮票组合问题*
解题思路:
用二进制数的每一位来代表是否选用该张邮票,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 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复