Python入門 回文かどうかを調べたいのですが?

回文かどうかを調べたいのですが?

回文とは、「上から読んでも下から読んでも同じ」文、または語句のことです。
ここでは簡単に「madam」や「racecar」が回文にあたるということで調査してみます。

方法1.forループでチェックする

#!/usr/local/env python3

def is_palindrome(string):
  # 文字列を半分に分割します。余りは切り捨てます。
  # print(len(string)//2) # 3
  for i in range(len(string) // 2): 
    # 文字列の先頭 `0` から順番に文字を取り出します
    print("string[",i,"]:" ,string[i])
    # 文字列の末尾 `-i-1` から順番に文字を取り出します。
    print("string[",-i,"-1]",string[-i-1]);
    # 先頭と末尾を比較します。
    # 同じであれば、先頭を一つ進め、末尾を一つ後退させます。
    if string[i] != string[-i - 1]:
      # 違っていたら即座に `for`を抜けて`False`を返します。
      return False
    # 先頭と末尾の比較が完了したら回文なので`True`を返します。
    print("先頭",i)
  return True

print(is_palindrome("racecar"))
# True
print(is_palindrome("python"))
# False
racecar :string[ 0 ]: r
racecar :string[ 0 -1] r
racecar :先頭 0
racecar :string[ 1 ]: a
racecar :string[ -1 -1] a
racecar :先頭 1
racecar :string[ 2 ]: c
racecar :string[ -2 -1] c
racecar :先頭 2
True
python :string[ 0 ]: p
python :string[ 0 -1] n
False

方法2.reversed()を使ってチェックする

def is_palindrome(string):
  return string == "".join(reversed(string))
print(is_palindrome("madam"))
print(is_palindrome("python"))
True
False

方法3.文字列スライスを使ってチェックする

import re
def is_palindrome ( string ) :
    string = re.sub ( r "[^a-zA-Z0-9]" , "" , string )
    string = string. lower ( )
    return string == string [ ::- 1 ]
print ( is_palindrome ( "racecar" ) )
print ( is_palindrome ( "python" ) )

sub() メソッドは、文字列から英数字以外の文字を削除するためにユーザー定義関数内で使用されます。
lower() メソッドは、文字列を小文字に変換するために使用されます。

True
False

指定された文字列が回文であるかどうかを確認するには、Python では forreversed()slicing が使用されます。
for は文字列を最初から最後まで繰り返し、各文字を反対の文字と比較して、議論されている条件をチェックします。
また、reversed()文字列スライス を使用して指定された文字列が回文であるかどうかを確認することもできます。

書籍の紹介

Python入門 `__str__`と`__repr__`ってなんですか?

Python入門 `__str__`と`__repr__`ってなんですか?

Python入門 リストの`-1`ってなんですか?

Python入門 リストの`-1`ってなんですか?