[南阳OJ-No.34]韩信点兵|相传韩信才智过人,从不直接清点自己军队的人数,只要让士兵先后以三人一排、五人一排、七人一排地变换队形,而他每次只掠一眼队伍的排尾就知道总人数了。输入3个非负整数a,b
来源:互联网 发布:虚拟机软件哪个好 编辑:程序博客网 时间:2024/05/01 06:41
南阳OJ-No.34
时间限制3000ms,内存限制65535KB,**难度1**
描述
相传韩信才智过人,从不直接清点自己军队的人数,只要让士兵先后以三人一排、五人一排、七人一排地变换队形,而他每次只掠一眼队伍的排尾就知道总人数了。输入3个非负整数a,b,c ,表示每种队形排尾的人数(a<3,b<5,c<7),输出总人数的最小值(或报告无解)。已知总人数不小于10,不超过100 。
输入
输入3个非负整数a,b,c ,表示每种队形排尾的人数(a<3,b<5,c<7)。例如,输入:2 4 5
输出
输出总人数的最小值(或报告无解,即输出No answer)。实例,输出:89
样例输入
2 1 6
样例输出
41
背景小故事
韩信点兵的成语来源淮安民间传说:刘邦曾经问他:你觉得我可以带兵多少?韩信:最多十万。刘邦不解的问:那你呢?韩信自豪地说:越多越好,多多益善嘛!刘邦半开玩笑半认真的说:那我不是打不过你?韩信说:不,主公是驾驭将军的人才,不是驾驭士兵的,而将士们是专门训练士兵的。
淮安民间传说着一则故事——“韩信点兵”,其次有成语“韩信点兵,多多益善”。韩信带1500名兵士打仗,战死四五百人,站3人一排,多出2人;站5人一排,多出4人;站7人一排,多出6人。韩信马上说出人数:1049。
思路
思路一:
最终的所求数num一定是被3整除后余x,被5整除后余y,被7整除后余z,且10<=num<=100。所以便利条件寻找即可。
思路二:
条件归并:找到X,Y,Z三个数组,分别存放除以3余x的数,除以5余x的数,除以3余y的数。
定义新方法,输入两个数组,返回两数组中第一个相同的数。
先对X,Y进行方法运算得到m,构建数组W除以m余(3*5=15)
对W,Z进行方法运算得到n,则最终结果=n+x*y*z。
凡是用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小为止。
JAVA
思路一
时间20,内存61
import java.util.Scanner;public class Main { public static Scanner cin = new Scanner(System.in); public static int x, y, z, num; public static void main(String[] args) throws Exception { x = cin.nextInt(); y = cin.nextInt(); z = cin.nextInt(); for (int i=10; i<=100; i++) { if ((i-x)%3==0) { if ((i-y)%5==0) { if ((i-z)%7==0) { System.out.println(i); break; } } } num = i; } if(num == 100) { System.out.println("No answer"); } }}
C++
思路一
时间0,内存240
#include <iostream>using namespace std;int main(){ int x, y, z, num; cin >> x >> y >> z; for (int i=10; i<=100; i++) { if ((i-x)%3==0) { if ((i-y)%5==0) { if ((i-z)%7==0) { cout << i; break; } } } num = i; } if(num == 100) { cout << "No answer"; }}
思路二
时间4,内存240
#include<iostream>using namespace std;int main(){ int a,b,c; cin >> a >> b >> c; int n=(a*70+b*21+c*15)%105; if(n>100||n<10) cout << "No answer" << endl; else cout << n << endl; }
- [南阳OJ-No.34]韩信点兵|相传韩信才智过人,从不直接清点自己军队的人数,只要让士兵先后以三人一排、五人一排、七人一排地变换队形,而他每次只掠一眼队伍的排尾就知道总人数了。输入3个非负整数a,b
- 韩信点兵 时间限制:3000 ms | 内存限制:65535 KB 难度:1 描述 相传韩信才智过人,从不直接清点自己军队的人数,只要让士兵先后以三人一排、五人一排、七人一排地变换队形,而他每次只
- 一排石头的游戏
- 一排石头的游戏
- NIM:一排石头的游戏
- 一排石头的游戏问题
- poj 1723 求中位数(让士兵站成一排)
- NIM(1) 一排石头的游戏
- #define 后面的定义要写在一排。
- MIN(1)一排石头的游戏
- NIM(1) 一排石头的游戏
- NIM(1)一排石头的游戏
- NIM(1)一排石头的游戏
- NIM(1) 一排石头的游戏
- 一排石头的游戏(续)
- 百度一道笔试题(求n个整数连成一排组成的最小整数)
- 3个A国人,3个B国人,3个C国人坐成一排。 要求不能使连续的3个人是同一个国籍.
- n个正整数联接成一排,组成一个最小的多位整数
- Android之设计模式
- 线程同步(互斥锁、读写锁、条件变量、信号量)
- ISP算法系统概念
- JS命名空间(namespace)
- POJ1845——等比数列的分治思想
- [南阳OJ-No.34]韩信点兵|相传韩信才智过人,从不直接清点自己军队的人数,只要让士兵先后以三人一排、五人一排、七人一排地变换队形,而他每次只掠一眼队伍的排尾就知道总人数了。输入3个非负整数a,b
- 3. SpringMVC框架之 注解开发篇
- 《Docker……》笔记-5 数据管理
- HDU 5950 Recursive sequence
- Xcode中的各种警告以及处理方法
- 好东西,分享一下,phpstron-163的service license
- Strus2与SpringMVC 对比
- redis ERR invalid DB index
- Java基础-静态块、非静态块、构造函数的执行顺序