韩信点兵
2017-02-22 11:26
148 查看
Think:
我怎么都觉得这题我是水过去的。。题目归类是while和do…while。。。然而我用的是暴力。。。。PTA天梯模拟题。。
思路:
明摆着报数原理就是取余运算嘛。所以我们只要找到一个Number同时满足
num % 5 == 1 num % 6 == 5 num % 7 == 4 num % 11 == 1 就可以啦~~~
题目:
在中国数学史上,广泛流传着一个“韩信点兵”的故事:韩信是汉高祖刘邦手下的大将,他英勇善战,智谋超群,为汉朝建立了卓越的功劳。据说韩信的数学水平也非常高超,他在点兵的时候,为了知道有多少兵,同时又能保住军事机密,便让士兵排队报数:
请编写程序计算韩信至少有多少兵。
输入格式:
本题无输入
输出格式:
输出韩信至少拥有的士兵人数。
我怎么都觉得这题我是水过去的。。题目归类是while和do…while。。。然而我用的是暴力。。。。PTA天梯模拟题。。
思路:
明摆着报数原理就是取余运算嘛。所以我们只要找到一个Number同时满足
num % 5 == 1 num % 6 == 5 num % 7 == 4 num % 11 == 1 就可以啦~~~
题目:
在中国数学史上,广泛流传着一个“韩信点兵”的故事:韩信是汉高祖刘邦手下的大将,他英勇善战,智谋超群,为汉朝建立了卓越的功劳。据说韩信的数学水平也非常高超,他在点兵的时候,为了知道有多少兵,同时又能保住军事机密,便让士兵排队报数:
按从1至5报数,记下最末一个士兵报的数为1; 再按从1至6报数,记下最末一个士兵报的数为5; 再按从1至7报数,记下最末一个士兵报的数为4; 最后按从1至11报数,最末一个士兵报的数为10;
请编写程序计算韩信至少有多少兵。
输入格式:
本题无输入
输出格式:
输出韩信至少拥有的士兵人数。
#include<bits/stdc++.h> using namespace std; const int MAX = 99999999; int main() { int i; for (i = 1;i <= MAX;i ++) { if (i%5==1&&i%6==5&&i%7==4&&i%11==10) { cout << i <<endl; break; } } return 0; }