0

以下の私のプログラムでは、2 つのクラスがあり、PalindromeTester は Palindrome のメソッド findPalindrome を参照することになっています。ただし、レベル、ママ、パパ、マダムなどの文字列をテストしても、findPalindrome メソッドに渡される値は常に入力文字列が回文ではありません。

改善を提案できますか?文字列を正しく調べていない findPalindrome メソッドだと確信しています。私はそれが方法だと思いますが、誰かが他の何かを見たら、自由に提案してください。最後から 2 番目の文字を取得して再構築し、元の文字列と比較します。

import java.util.Scanner;//import scanner class

public class PalindromeTester//class
{
   public static void main(String args[])//main method
   {
      Scanner in = new Scanner(System.in); //scanner object
      String palindrome = new String(); //string to accept user input

      String end = new String("q"); //string to determine user quitting

      for (int a = 0; a >= 0; a++){ //enter loop 
      System.out.println(); 
      System.out.println("Enter a string to check if it is a palindrome"); //ask for initial string 
      System.out.println(); 
      System.out.println("Continue entering strings until you are done. When you are done, enter q to quit."); //remind user to enter q to quit
      palindrome = in.nextLine();//take in string input
      Palindrome original = new Palindrome(palindrome); //palindrome object and passed palindrome to the constructor...but no value yet...so? 
      original = original.findPalindrome(); //call findPalindrome to determine if palindrome is a palindrome

      if (palindrome.equalsIgnoreCase(end)) //if palindrome is q and since end is q and if they are equal, a=-2.  
        a = -2; //when incrementing the max value if ++ will be -1. since -1 is not >= to 0 then for loop exits. 
      System.out.println("Thanks for trying this program"); 

     }  
   }
 }

_____________________________________________________________

    public class Palindrome { 
      String myPalindrome;  
      String myReverse; 

      public Palindrome(){
        myPalindrome = new String(""); 
        myReverse = new String(""); 
      }

      public Palindrome(String palindrome){
        myPalindrome = palindrome; 
      }

      public String findPalindrome (){

          int length = myPalindrome.length();

          for ( int i = length - 1 ; i >= 0 ; i-- )
             myReverse = myReverse + myPalindrome.charAt(i);

          if (myPalindrome.equals(myReverse))
            System.out.println("Entered string is a palindrome.");
          else
            System.out.println("Entered string is not a palindrome.");

          return (""); 
      }


    }
4

1 に答える 1