0

这不是“寻找数字的回文”!它比这有点扭曲:

步骤 1:反转原始号码的数字。

第 2 步:添加颠倒的数字。

第 3 步:如果新号码是回文号码,则打印输出。

限制是 15 步,如果这本身是回文,我们可以打印原始数字。我们必须在这个程序中使用函数调用。在这里,我使用了两个函数() - 首先是反转数字,其次是添加原始数字和反转的数字并检查总和是否是回文。

如果我能以任何方式改进这个长代码,请提出您的意见。

PS:Java新手,尤其是函数调用!

谢谢!!这是代码,有点长!对不起 :(

import java.util.*;
public class PalindromicNumber
{
 public int PalinReverse(int n)
    {
     int n1=n;
     int x1=0, d1=0;
      while (n1>0)//just used to store the reverse of the original number
        {
          d1=n1%10;
          x1=(x1*10)+d1;
          n1=n1/10;
        }
    return x1;
     }

    public int PalinCheck (int n, int p)
      {
         int F=0;
         F=n+p; 
         int n1=F, x1=0, d1=0;

          while(n1>0)//checks if the sum of reversed no. and the original number is palindrome or not
           {
            d1=n1%10;
            x1=(x1*10)+d1;
            n1=n1/10;
           }
   if (x1==F)
       {
       System.out.println("The number"+ F +"is a Palindrome");
       return 1;
       }
   else 
       return F; //returns the sum if it is not a palindrome
    }

   public static void main (String args[])
     {
      Scanner sc=new Scanner(System.in);
      PalindromicNumber ob=new PalindromicNumber();

      System.out.println("Enter the original number");
      int n=sc.nextInt();

      int count=0;
      int n1=n, x1=0, d1=0;
        while(n1>0) //this checks if the original no. is a palindrome or not
           {
            d1=n1%10;
            x1=(x1*10)+d1;
            n1=n1/10;
           }

        if (x1==n)
        System.out.println("The original number="+n+"is a palindrome number");

        else

        for (count=0;count<15;count++)
           {
               int a=ob.PalinReverse(n);
               System.out.println("The reversed number is"+a);
               int b=ob.PalinCheck(n,a);
                if(b==1)
                {
                    System.out.println("The no. of steps it took was"count+1);
                    break;// the palindromic no. is now found out
                } 
                else 
                     n=b;//used to update the value of n
           }
    }
}
4

1 回答 1

0

问题出在你的PalinReverse方法上。您的while循环无限运行,因为条件始终为真。

代替

while (n>0)

while (n1>0)

您还应该学习如何调试程序。在那之后你的生活会轻松10倍。

于 2017-02-25T19:54:08.313 回答