验证角谷猜想:任给一个自然数,若为偶数除以2,若为奇数则乘3 加1, 得到一个新的自然数后按照上面的法则继续计算,若干次后得到的结果必然为1。 要求:读入一个自然数,输出计算的步骤。

package sfsd;
//导包

import java.util.Scanner;

public class Text{
//主函数
public static void main(String[] args) {
System.out.println("请输入一个自然数");
Scanner sc=new Scanner(System.in);
int a=sc.nextInt();
for(int i=0;;i++) {
if(a%2==0) {
//引用为奇数时的函数
a=ou(a);
}else {
//引用为偶数时的函数
a=ji(a);
}
if(a==1) {
System.out.println("经过"+i+"次计算后");
break;
}
}
System.out.println("得到"+a);
}
public static int ji(int a) {
int b=a*3+1;
return b;
}
public static int ou(int a) {
int b=a/2;
return b;
}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 角谷猜想一个数学猜想,它的内容是:任给一个自然数若为偶数除以2,若为奇数则乘31,得到一个自然数后,按照上面法则继续演算,若干次得到的结果必然为1。现在需要编写一个程序来验证这个猜想,并输出进行演算的次数。 ### 回答2: 角谷猜想一个有趣且神秘的数学问题。它的规则相对简单,即对于任何一个自然数,如果它是偶数,就将它除以二,如果它是奇数,就将它乘以三再上一,直到最终得到的结果为1为止。 那么如何用编程验证这个猜想呢?下面是一个可能的解决方案: 首先,定义一个函数,叫做JG(n),它的参数为自然数n,返回值为角谷猜想的演算次数。然后,我们可以按照规则进行迭代计算,每一次得到的数都将参数传入JG(n)中,统计演算的次数。最后,当得到的结果为1时,返回演算次数。 代码如下: ``` def JG(n): if n == 1: return 0 # 如果n为1,演算次数为0 elif n % 2 == 0: return JG(n // 2) + 1 # 如果n为偶数,演算次数1,然后继续进行演算 else: return JG(n * 3 + 1) + 1 # 如果n为奇数,同上 x = int(input("请输入一个自然数:")) res = JG(x) print("演算次数为:", res) ``` 在这个程序中,JG函数的递归调用确保了正确的迭代过程,同时,每一次调用JG函数,演算次数都会1,直到最终结果为1停止。程序输出的演算次数就是角谷猜想所需要的迭代次数。 总之,角谷猜想一个神秘而有趣的问题,通过编程验证它的正确性既是一项挑战,也是一种探索数学的方式。 ### 回答3: 角谷猜想一个已知的数学难题,其内容为对于任意一个自然数,按照以下法则进行反复演算,最终必定会得到1:若该数为偶数,则将其除以2;若该数为奇数,则将其乘以3再1。该猜想尚未被证明,但在计算机科学中,可以编程验证其正确性。 我们可以使用Python来编写验证角谷猜想的代码: ``` def jiaogu(n): count = 0 while n != 1: if n % 2 == 0: n = n // 2 else: n = n * 3 + 1 count += 1 return count n = int(input("请输入一个自然数:")) count = jiaogu(n) print("经过", count, "次演算后,", n, "最终得到了1。") ``` 代码中,我们首先定义一个名为`jiaogu`的函数,用于实现角谷猜想的演算过程。该函数接收一个自然数`n`作为参数,并使用`while`循环进行反复演算,直到`n`的值为1。在每一次循环中,如果`n`是偶数,则将其除以2,否则将其乘以3再1。同时,我们使用一个`count`变量来记录演算次数,并在函数的最后将其返回。 接下来,我们通过`input`函数获取用户输入的一个自然数,并调用`jiaogu`函数对其进行演算。最后,我们输出经过演算次数以及演算结果。 通过以上代码,我们可以验证角谷猜想的正确性,并计算出进行演算的次数。当输入的自然数越大时,演算次数也会越多,这可能是该猜想尚未被证明的原因之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值