我使用以下代码来解决问题#14,但由于某种奇怪的原因它没有输出。也许运行时间太长???PSI 知道 max 不应该是答案,但无论如何仍然没有输出,而对于像 i<100 这样的较小值,我得到了输出。
#include <iostream>
long collatz(long);
int main()
{
using namespace std;
long i=3,max;
for(i=3;i<1000000;i++)
{
max=collatz(i-1);
if(collatz(i)>collatz(i-1))
{
max=collatz(i);
}
else
{
max=collatz(i-1);
}
}
cout<<max<<endl;
cin.clear();
cin.get();
}
long collatz(long n)
{
int count=0;
while(n!=1)
{
if(n%2==0)
{
n=n/2;
count+=1;
}
else
{
n=3*n+1;
}
}
return count;
}