#python #python-3.x
#python #python-3.x
Вопрос:
Я пытаюсь изменить код, чтобы игнорировать пробелы в строке палиндрома. Например, код должен быть помечен Do Geese See God
как Palindrome. Я пытался использовать .replace(" ", "")
, но либо появляется ошибка, либо палиндром возвращается как False
.
stk = Stack()
for i in range(len(sentence)):
stk.push(sentence[i])
for i in range(stk.size()):
stk.replace(" ","")
if sentence[i] != stk.pop():
return False;
return True;
Кстати, я пытаюсь не использовать stk.item[-1]
or stk.item == stk.item[::-1] in Stack
.
Комментарии:
1. Затем определите пробел в вашей замене. Так и должно быть
.replace(" ","")
.2. Кстати, ваша тестовая фраза не является палиндромом. Возможно, изменить
Does
наDo
?
Ответ №1:
Я бы рекомендовал просто удалить все пробелы с помощью регулярного выражения:
input = " A man a plan a canal Panama "
input = re.sub(r's ', '', input)
Это также обработало бы случаи начальных и конечных пробелов, которые вы, вероятно, также захотите игнорировать.
Комментарии:
1. Спасибо, я думал об использовании регулярного выражения, но код будет принимать пользовательский ввод, а затем решил, является ли это палиндромом или нет, я отредактирую вопрос, чтобы отразить это.
Ответ №2:
Возможно, это ошибка вырезания и вставки, но на самом деле у вас нет пробела в том, что вы заменяете.
stk.replace(' ', '')
Ответ №3:
Я изменил код, чтобы заставить это работать:
def isPalindrome(sentence):
sentence = sentence.replace (' '. '')
stk = Stack()
for i in range(len(sentence)):
stk.push(sentence[i])
for i in range(stk.size()):
stk.replace(' ','')
if sentence[i] != stk.pop():
return False;
return True;
Комментарии:
1. Кажется, что
stk.replace(' ','')
в этом нет необходимости