关于韩信点兵:淮安民间传说着一则故事——“韩信点兵”,其次有成语“韩信点兵,多多益善”。韩信带1500名兵士打仗,战死四五百人,站3人一排,多出2人;站5人一排,多出4人;站7人一排,多出6人。韩信马上说出人数:1049。

2. 解题思路

思路一:可以先求出三组数,这三组数分别是分别用3,5,7除总人数在规定范围内所有的可能数值,然后求得这三组数中相同的那个数即可。

例如:一个数除以3余2,除以5余3,除以7余2,求符合条件的最小数。

解:先列出除以3余2的数:2,5,8,11,14,17,20,23,26……。再列出除以5余3的数:3,8,13,18,23,28……。这两列数中,首先出现的公共数是8。3与5的最小公倍数是15。两个条件合并成一个就是8+15×整数,列出这一串数是8,23,38,……,再列出除以7余2的数2,9,16,23,30……。就得出符合题目条件的最小数是23。

事实上,我们已把题目中三个条件合并成一个:被105除余23。

具体代码如下:

1 importjava.util.Scanner;2

3 public classMain {4

5 public static voidmain(String[] args){6

7 Scanner cin = newScanner(System.in);8 int a = cin.nextInt(), b = cin.nextInt(), c =cin.nextInt();9 int re = 0;10 for(int i = 9 + a; i < 101; i = i + 3){11 for(int j = 10 + b; j < 101; j = j + 5){12 for(int k = 7 + c; k < 101; k = k + 7){13 if(i == j && j ==k){14 re =i;15 break;16 }17 }18 }19 }20 System.out.println(re);21 cin.close();22 }23 }

思路二:凡是用3除剩下的余数,将它用70去乘(因为70是5与7的倍数,而又是以3去除余1的数);5除剩下的余数,将它用21去乘(因为21是3与7的倍数,又是以5去除余1的数);7除剩下的余数,将它用15去乘(因为15是3与5的倍数,又是以7去除余1的数),将这些数加起来,若超过105,就减掉105,如果剩下来的数目还是比105大,就再减去105,直到得数比105小为止。这样,所得的数就是原来的数了。

如上个例子:2*70+3*21+2*15 = 233  ,  233-(105*2)=23

代码很简单,我就不写了。

3. 参考资料

韩信点兵php,ACM试题 - 韩信点兵相关推荐

  1. 韩信点兵python程序_韩信点兵计算公式与代码

    韩信点兵计算公式与代码 问题描述: 淮安民间传说着一则故事--"韩信点兵",其次有成语"韩信点兵,多多益善". 韩信带1500名兵士打仗,战死四五百人,站3人一 ...

  2. 韩信点兵,在中国数学史上,广泛流传着一个“韩信点兵”的故事:韩信是汉高祖刘邦手下的大将,他英勇善战,智谋超群,为汉朝建立了卓越的功劳。据说韩信的数学水平也非常高超,他在点兵的时候,为了知道有多少兵,

    7 韩信点兵 在中国数学史上,广泛流传着一个"韩信点兵"的故事:韩信是汉高祖刘邦手下的大将,他英勇善战,智谋超群,为汉朝建立了卓越的功劳.据说韩信的数学水平也非常高超,他在点兵的时 ...

  3. ACM试题 - 括号配对问题 - Java中字符串截取和定位问题

    ACM试题题源(括号配对问题):http://acm.nyist.net/JudgeOnline/problem.php?pid=2 提交代码: import java.util.Scanner;pu ...

  4. ACM试题 - 另一种阶乘问题

    1. ACM试题题源:http://acm.nyist.net/JudgeOnline/problem.php?pid=65 描述 大家都知道阶乘这个概念,举个简单的例子:5!=1*2*3*4*5.现 ...

  5. ACM试题 - ASCII码排序 - Java中字符与对应ASCII码的转换

    Java中字符转换对应ASCII码有两种方式: 第一种: char c = 'a'; byte b = (byte)c; // b=97 第二种: char c = 'a'; int b = c; / ...

  6. 赛马网ACM试题(原杭电oj ACM)java版答案(1000,10001,1002)

    赛马网ACM试题(原杭电OJ ACM试题)答案(java版) Author : Zhang Hailong   Date   : 2015-09-17    HomePage : http://  E ...

  7. Java三齐王乱点兵算法,【ACM】韩信点兵算法

    题目是:韩信点兵 Time Limit: 1000MS Memory Limit:65536 Description : 带队人员想知道一共有多少人参加了活动. 于是分别让同学们 6人一列,5人一列, ...

  8. 22. 韩信点兵:在中国数学史上,广泛流传着一个“韩信点兵”的故事:韩信是汉高祖刘邦手下的大将,他英勇善战,智谋超群,为汉朝建立了卓越的功劳。据说韩信的数学水平也非常高超,他在点名的时候,为了知道有多

    在这里插入代码片 #include"stdio.h" main() {int i;for(i=1;;i++){if(i%5==1&&i%6==4&& ...

  9. 韩信点兵python算法_韩信点兵和搬砖问题

    「你将学到什么?」 编程实战算法与世界五百强面试,不是念PPT,我们讲的就是实战与代码实现与企业应用.程序 = 数据结构 + 算法 --图灵奖得主,计算机科学家N.Wirth(沃斯) 作为程序员,我们 ...

最新文章

  1. 2022-2028年中国游泳健身行业市场研究及前瞻分析报告
  2. 常用快捷键整理,提升工作效率!
  3. PAT甲级1131 Subway Map (30分):[C++题解]堆优化dijkstra、单源最短路、地铁地图、巧妙地建图套dijkstra模板!!
  4. 曲线抽稀 java_Python实现曲线点抽稀算法
  5. XML文件操作(C#)
  6. AliExpress智能营销引擎大揭秘 - AnalyticDB如何做到快准狠省
  7. 【AI视野·今日NLP 自然语言处理论文速览 第十期】Fri, 18 Jun 2021
  8. 安徽省第二次计算机水平考试,2006第二次安徽省计算机水平考试试卷(ACCESS).doc...
  9. 已知起点坐标、角度、长度求终点坐标
  10. Codeforces Round #215 (Div. 2) 解题报告
  11. 关于opencv中的imread()函数声明
  12. 数据来看吃热狗王校长的微博究竟有多火!
  13. v50进9008救砖
  14. 4.4-软件开发中,“UI设计图”的作用与绘制方法说明
  15. 关于(C++)数据结构复数计算器作业的拓展
  16. SAP 自动记账 零星记录
  17. 三种等待方式:强制等待、显式等待、隐式等待
  18. 冒险岛手游哪个服务器稳定,冒险岛手游现在十个职业哪个后期最强
  19. 好看的渐变色网址收藏
  20. toad for oracle12.11,Toad for Oracle

热门文章

  1. 快速测试网速软件,‎App Store 上的“测网速大师 - 一键测网速”
  2. tensorflow 中文字体训练集_深度学习与TensorFlow:自建手写字体数据集上的模型测试...
  3. Python-Django毕业设计学校旧书交易网站(程序+Lw)
  4. volatile如何保证可见性
  5. 即兴演讲的“三定”和“四思”、“五借”技巧
  6. 房地产集团数据平台案例
  7. 20世纪最优秀的物理学家费曼是如何生活、学习和思考的?
  8. 23种java设计模式之模板模式
  9. 谷歌浏览器知网搜索内容显示不全解决方法
  10. 泛在电力物联网下的远程抄表和设备监控维护