对于任意一个正整数,若为偶数,就把它除以2;若为奇数,就把它乘以3再加1。经过如此有限次的计算之后,总是会得到数值1,这就是角谷猜想。现给定一个正整数n(n≤100,000,000),求经过多少次计算可以得到1,输出所需次数t。
时间: 2024-06-05 09:06:10 浏览: 147
整数分解(递归实现),大于1的正整数n可以分解为n=x1*x2*x3`···xm
5星 · 资源好评率100%
思路:
按照题目描述,很容易想到使用循环来实现,每次判断当前数是奇数还是偶数,做出相应的操作,直到得到1。但是,n的范围非常大,如果直接使用循环的话,时间复杂度会很高,无法通过此题。
因此,我们需要寻找一种更高效的算法。
观察题目,发现每次操作后,如果得到的是偶数,那么下一次操作的数就是原数的一半,如果得到的是奇数,那么下一次操作的数就是原数乘以3再加1。这个过程可以看做是一个序列,每次操作得到的数是序列中的下一个数,直到得到1为止。
我们可以从n开始,不断对这个数做出操作,直到得到1。在这个过程中,我们可以记录下每一次操作得到的数,从而构成一个序列。因为n的范围不大,所以这个序列的长度也不会很大,我们可以把这个序列存储下来,避免重复计算。
当我们得到1时,我们就知道了这个序列的长度,也就是需要的操作次数。
代码:
阅读全文