原题链接:C语言训练-邮票组合问题*
解题思路:
1. 使用数组保存结果,循环数组,统计数组中进行标记了的元素。
2. 使用集合Set保存结果,输出集合Set的size。
注意事项:
至少使用一张邮票,故两者都不用的情况应该进行过滤。
参考代码:
public class C1154 { public static void main(String[] args) { int a = 3, n = 4, b = 5, m = 3; int[] arr = new int[a*n+b*m+1]; for(int i = 0; i <= n; i++){ for(int j = 0; j <= m; j++){ if(j != 0 || i != 0) arr[a*i+b*j] = 1; } } int count = 0; for(int i = 0; i <= n; i++){ for(int j = 0; j <= m; j++){ if(arr[a*i+b*j] == 1) count++; } } System.out.println(count); } }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复