对于任意一个正整数,若为偶数,就把它除以2;若为奇数,就把它乘以3再加1。经过如此有限次的计算之后,总是会得到数值1,这就是角谷猜想。现给定一个正整数n(n≤100,000,000),求经过多少次计算可以得到1,输出所需次数t。
时间: 2024-06-05 17:06:10 浏览: 158
思路:
按照题目描述,很容易想到使用循环来实现,每次判断当前数是奇数还是偶数,做出相应的操作,直到得到1。但是,n的范围非常大,如果直接使用循环的话,时间复杂度会很高,无法通过此题。
因此,我们需要寻找一种更高效的算法。
观察题目,发现每次操作后,如果得到的是偶数,那么下一次操作的数就是原数的一半,如果得到的是奇数,那么下一次操作的数就是原数乘以3再加1。这个过程可以看做是一个序列,每次操作得到的数是序列中的下一个数,直到得到1为止。
我们可以从n开始,不断对这个数做出操作,直到得到1。在这个过程中,我们可以记录下每一次操作得到的数,从而构成一个序列。因为n的范围不大,所以这个序列的长度也不会很大,我们可以把这个序列存储下来,避免重复计算。
当我们得到1时,我们就知道了这个序列的长度,也就是需要的操作次数。
代码:
相关问题
输入一个正整数,若为偶数,则除以2,若为大于1的奇数,则乘以3加1
这是著名的Collatz猜想,目前还没有被证明或者被反驳。以下是一个简单的Python实现:
```
def collatz(n):
if n == 1:
return [1]
elif n % 2 == 0:
return [n] + collatz(n // 2)
else:
return [n] + collatz(n * 3 + 1)
n = int(input("请输入一个正整数:"))
print(collatz(n))
```
例如,输入13,输出为:
```
[13, 40, 20, 10, 5, 16, 8, 4, 2, 1]
```
输入一个正整数,若为偶数,则除以2,若为大于1的奇数,则乘以3加1。求经过多少次得到数1
这是一个著名的数学问题,被称为“Collatz猜想”。目前还没有被证明,但已经被计算机验证了数百万次。根据计算机验证的结果,对于任何一个正整数,最终都会得到1。至于经过多少次得到1,这取决于初始的正整数。
阅读全文