如何判断用户输入的字符串是否被反向读取相同(回文)JAVA[关闭] JAVA[微博]。

问题描述 投票:0回答:2
package com.jetbrains;

import java.util.Objects;
import java.util.Scanner;

public class SA {

    public static void main(String[] args) {

        //scanner object
        Scanner input = new Scanner(System.in);

        //comment 
        System.out.println("Please enter a line of text below:");
        String letters = input.nextLine(); //User's string input

        if (letters.length() < 7) {
            System.out.println("The input is too short.");
        }

        //variables
        int l = letters.length()-5; //where the last 5 characters are located in user's input string
        String answer = letters.substring(l) + letters.substring(2,l) + letters.substring(0, 2); // first 2 & last 5 swapped


        if (letters.length() > 7) {
            System.out.println("Convert to upper cases:"); 
            System.out.println(letters.toUpperCase());

            System.out.println("Swap the first 2 characters with the last 5 characters:"); // Swap
            System.out.println(answer);

            System.out.println("Is it a palindrome?");

            for (int i = (letters.length() - 1); i >= 0; i--) {
                char backwards = (letters.charAt(i));

                for (int n = letters.indexOf(0); n >= 0; n++) {
                    char forwards = (letters.charAt(n));

                    if (Objects.equals(forwards, backwards)) {
                        System.out.println("True");
                        else
                           System.out.println("False");
                    }


                }
            }
        }

    }
}

我试过通过将for-loop的输出变成char变量来比较用户的输入,但它总是返回false。我不知道如何解决最后一点,我试过做其他的事情,但我完全陷入了困境。我的类还没有学会StringBuilder或StringBuffer,所以我不能在我的代码中使用它们。任何技巧或提示都会很有帮助,谢谢你。

java string for-loop palindrome
2个回答
0
投票

我修改了一下你的代码,得到了正确的结果--。

import java.util.Scanner;

public class StringAnalysis {

    public static void main(String[] args) {

        //Create scanner object
        Scanner input = new Scanner(System.in);

        //Comment to the user
        System.out.println("Please enter a line of text below:");
        String letters = input.nextLine(); //User's string input

        if (letters.length() < 7) {
            System.out.println("The input is too short. No analysis to be performed.");
        }

        //variables
        int l = letters.length() - 5; //States the index number of where the last 5 characters are located in user's input string
        String answer = letters.substring(l) + letters.substring(2, l) + letters.substring(0, 2); // first 2 & last 5 swapped


        if (letters.length() > 7) {
            System.out.println("Analysis #1: Convert to upper cases:"); // Upper case
            System.out.println(letters.toUpperCase());

            System.out.println("Analysis #2: Swap the first 2 characters with the last 5 characters:"); // Swapping
            System.out.println(answer);

            System.out.println("Analysis #3: Is it a palindrome?");


            String backwards = "";
            for (int i = (letters.length() - 1); i >= 0; i--) {
                backwards = backwards + letters.charAt(i);
            }

            if(letters.equalsIgnoreCase(backwards)) {
                System.out.println("True");
            } else {
                System.out.println("False");
            }
        }
    }
}

0
投票

你有一个问题,在第二个循环检查palindrome,我试图解决它,但即使,它比较每一个后向字母和所有前向,这是逻辑错误,这里有一些更好的东西,你可以做。

System.out.println("Analysis #3: Is it a palindrome?");
        boolean response = true;
        for (int i = 0 ; i < letters.length() ; i++) {
            String backwards = String.valueOf(letters.charAt(i));
            String forwards = String.valueOf(letters.charAt(letters.length()-i-1));

                if(!backwards.equals(forwards)) {
                    response = false;
                }

        }
        System.out.println(response);
© www.soinside.com 2019 - 2024. All rights reserved.