ホームページ >Java >&#&チュートリアル >回文文字列チェックを最適化するにはどうすればよいでしょうか?
回文チェック用のコードの改善
文字列が回文であるかどうかをチェックするために、両端の文字を比較するメソッドを開発しました。真ん中に向かって。ただし、最適化の余地はあります。
最適化されたアプローチ:
次のコードは、よりシンプルで効率的なソリューションを提供します:
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; }
説明:
このコードは 2 つのポインターを利用します。 i1 と i2 は、それぞれ単語の先頭と末尾に初期化されます。 i2 が i1 と交差するまで内側に反復されます。
ポインタが移動するとき
例:
単語 "andna" の場合:
ループ反復:
メソッドは true を返し、確認します。その「andna」は回文です。
以上が回文文字列チェックを最適化するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。