0
int Cnt(){
    return Count (10);
}

int Count (int init){
    int u = init % 10;
    int t = (init % 100) - u;
    int u2 = u * u;
    int t2 = t * t;
    int m = u2 + t2;
    if(m <= 1)
        System.out.println("Happy!");
    else {
        return Count (m);
    }

此代码应该(理论上)检查 number 是否为Happy,如果不是,则将初始值设置为与结果相同并且整个过程重复。如果数字不满意,应该会发生无限循环。然而这一切都没有发生,有谁知道如何使这项工作?

4

4 回答 4

0

根据您链接的Wiki文章,您必须重复对每个数字中的数字求和的过程。以 7 为例:

7^2 = 49
49  = 4^2 + 9^2 = 16 + 81 = 97
97  = 9^2 + 7^2 = 81 + 49 = 130
130 = 1^2 + 3^2 = 10
10  = 1^2 = 1

我发现您的代码存在一些问题。首先,您没有将十位数除以 10,这意味着对于数字 52,您将得到 u = 2,并且 t = 50,而不是 5。这部分,我相信您可以轻松解决。

其次,如果您的号码不满意,您似乎永远不会得出结论。例如数字 4,你将达到 16、37、72、53、34、25、29、85、89、145、42、20、4。但是你的程序,因为你无法检查你已经进入了一个循环,将一直运行到内存不足为止。

于 2012-07-29T18:55:33.593 回答
0
import java.io.*;
class happy_no
{
    void happy(double n)
    {
        int c=0;
        double s=0;
        double d,p,i,_sa;
        for(i=1;i<=n;i++)
        {
            while(n!=0)
            {
                d=n%10;
                p=d*d;
                s=s+p;
                n=n/10;
            }
            if(s==1)
            {
                System.out.println("HAPPY NO.");
                break;
            }
            else
            {
                n=s;
            }
        }
    }
    public static void main()throws IOException
    {
        InputStreamReader read=new InputStreamReader(System.in);
        BufferedReader in=new BufferedReader(read);
        double a;
        System.out.println("ENTER A NO.");
        a=Double.parseDouble(in.readLine());
        happy_no obj=new happy_no();
        obj.happy(a);
    }
于 2015-02-03T08:57:38.860 回答
0

由于这是家庭作业,我没有给出答案……但这是线索……

您没有很好地处理 3 位数字。

t=init%100-u计算为10%100-0 = 10

一旦m=u2+t2iem=0+100到达100并且您的程序无法处理 3 位数字。希望这可以帮助。

添加以下...

int h = init/100;
int h2 = h * h;
int m = u2+t2+h2;

它应该让你继续前进...... :)

于 2012-07-29T18:51:08.607 回答
0

尝试使用您引用的文章中概述的方法:

private static boolean isHappy(int number)
{
   List<Integer> set = new ArrayList<Integer>();

   while (number > 1 && !set.contains(number))
   {
       set.add(number);

       number = sumSquaresOfDigits(number);
   }

   return number == 1;
}

private static int sumSquaresOfDigits(int number)
{
    String numberString = Integer.toString(number);

    int result = 0;

    for (char character : numberString.toCharArray())
    {
        int digit = Character.digit(character, 10);

        result += digit * digit;
    }

    return result;
}

这可以通过计算所有 10 位数字 (0-9) 的平方并将结果存储在整数数组中来更有效地完成。

于 2012-07-29T19:21:41.807 回答