Description:
有这样一个游戏:从一个正整数开始,两人轮流进行如下运算:
若是奇数,就把这个数乘以 3 再加 1;若是偶数,就把这个数除以 2。这样演算下去,直到
第一次得到 1 才算结束,首先得到 1 的获胜。
比如,要是从 1 开始,就可以得到 1 4 2 1;要是从 17 开始,则可以得到
17 52 26 13 40 20 10 5 16 8 4 2 1。
这个问题就是叙拉古猜想,也叫科拉兹猜想或角谷猜想。
现在,你和你的朋友一起玩这个游戏,由你先开始,请问谁获胜?
Input:
第一行 N(N<=500),接下来 N 行,每行一个整数 M(M<=10,000,000),表示你拿到的数字
式 M。
Output:
输出 N 行,如果是你获胜,输出“I win!”,否则输出“I lost!”。
Sample Input:
2
1
17
Sample Output:
I win!
I lost!
怎样用Java证明叙拉古猜想?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- CSDN专家-天际的海浪 2021-12-10 03:26关注
你题目的解答代码如下:
import java.util.*;//导包 class HelloWorld { public static void main(String []args) { Scanner sc = new Scanner(System.in); int n,i,m,c; n = sc.nextInt(); for (i=0;i<n; i++){ c = sc.nextInt(); m = 0; do { if (c % 2 == 1) c = c*3+1; else c = c / 2; m++; } while (c!=1); if (m % 2 == 1) System.out.println("I win!"); else System.out.println("I lost!"); } } }
如有帮助,望采纳!谢谢!
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
- ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
- ¥20 软件测试决策法疑问求解答
- ¥15 win11 23H2删除推荐的项目,支持注册表等
- ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
- ¥15 qt6.6.3 基于百度云的语音识别 不会改
- ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
- ¥15 神经网络怎么把隐含层变量融合到损失函数中?
- ¥15 lingo18勾选global solver求解使用的算法
- ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行