>Java >java지도 시간 >문자열이 회문인지 효율적으로 확인하는 방법은 무엇입니까?

문자열이 회문인지 효율적으로 확인하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-26 10:16:13743검색

How to Efficiently Determine if a String is a Palindrome?

문자열에서 회문을 효과적으로 확인하는 방법

문자열에서 회문을 확인하려면 양쪽 방향에서 동일하게 읽는지 확인해야 합니다. 이 작업에 대한 간단한 접근 방식은 문자열을 문자 배열로 변환하고 인접한 요소를 비교하는 것입니다.

다음은 이 접근 방식의 샘플 구현입니다.

public class Aufg1 {
    // Main method for testing
    public static void main(String[] args) {
        String wort = "reliefpfpfeiller";
        char[] warray = wort.toCharArray();
        System.out.println(istPalindrom(warray));
    }

    // Method for checking palindromes
    public static boolean istPalindrom(char[] word) {
        boolean palindrom = false;
        if (word.length % 2 == 0) {
            for (int i = 0; i < word.length / 2 - 1; i++) {
                if (word[i] != word[word.length - i - 1]) {
                    return false;
                } else {
                    palindrom = true;
                }
            }
        } else {
            for (int i = 0; i < (word.length - 1) / 2 - 1; i++) {
                if (word[i] != word[word.length - i - 1]) {
                    return false;
                } else {
                    palindrom = true;
                }
            }
        }
        return palindrom;
    }
}

이 코드는 문자 배열을 반복합니다. , 반대쪽 끝에 있는 요소를 비교하여 일치하는지 확인합니다. 그러나 시작과 끝에서 시작하는 요소를 동시에 비교하는 보다 최적화된 접근 방식이 존재합니다.

개선된 코드:

public static boolean istPalindrom(char[] word) {
    int i1 = 0;
    int i2 = word.length - 1;
    while (i2 > i1) {
        if (word[i1] != word[i2]) {
            return false;
        }
        ++i1;
        --i2;
    }
    return true;
}

예:

입력 문자열 "andna"를 문자열로 사용 예:

  • i1을 0(문자열의 시작을 나타냄)으로, i2를 4(끝을 나타냄)로 초기화합니다.
  • 루프는 단어[0](a)를 다음과 비교합니다. word[4] (a).
  • i1은 1로 증가하고 i2는 다음으로 감소합니다. 3.
  • 단어[1](n)과 단어[3](n)을 비교하면서 루프가 계속됩니다.
  • i1은 2로 증가하고 i2는 2로 감소합니다.
  • 이제 i1은 i2와 동일하므로 루프가 종료되고 함수는 true를 반환하여 문자열이 다음임을 나타냅니다. 회문.

위 내용은 문자열이 회문인지 효율적으로 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.