这是获取回文的正确方法吗?我得到了结果,但不确定

发布于 2025-02-11 19:33:36 字数 736 浏览 2 评论 0原文

我试图剥离“永不奇怪甚至”以删除空格,但它没有起作用,或者我没有正确地进行操作。
因此,我试图将字符串分为列表,然后加入它们,以使所有空格都将被删除。

这是代码:

def is_palindrome(input_string):
    new_string = ""
    reverse_string = ""
    lowerinput = input_string.lower()
    splitinginput = lowerinput.split()
    for new_string in lowerinput:
        if lowerinput[0] == lowerinput[-1]:
            new = new_string.join(splitinginput)
            reverse_string = new_string[::-1]
    if new_string == reverse_string:
        return True
    return False

print(is_palindrome("Never Odd or Even")) # Should be True
print(is_palindrome("abc")) # Should be False
print(is_palindrome("kayak")) # Should be True

对不起,我是新来的,这个问题可能很幼稚,但我很想知道您的反馈。

I tried to strip the "Never Odd or Even" to remove the whitespaces but it didn't worked or i was not doing it correctly.
So I tried to split the string into list and then join them such that all the whitespace would be removed.

here is the code :

def is_palindrome(input_string):
    new_string = ""
    reverse_string = ""
    lowerinput = input_string.lower()
    splitinginput = lowerinput.split()
    for new_string in lowerinput:
        if lowerinput[0] == lowerinput[-1]:
            new = new_string.join(splitinginput)
            reverse_string = new_string[::-1]
    if new_string == reverse_string:
        return True
    return False

print(is_palindrome("Never Odd or Even")) # Should be True
print(is_palindrome("abc")) # Should be False
print(is_palindrome("kayak")) # Should be True

Sorry i am new and this question could be little naive but i would love to know your feedback..

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

喜爱纠缠 2025-02-18 19:33:36

这是我的解决方案

def is_palindrome(input_string):
   input_string = input_string.lower()
   input_string = "".join(input_string.split())
   reverse_string = input_string[::-1]
   if input_string == reverse_string:
      return True
   else:
      return False
print(is_palindrome("Never Odd or Even")) # Should be True
print(is_palindrome("abc")) # Should be False
print(is_palindrome("kayak")) # Should be True

this is my solution

def is_palindrome(input_string):
   input_string = input_string.lower()
   input_string = "".join(input_string.split())
   reverse_string = input_string[::-1]
   if input_string == reverse_string:
      return True
   else:
      return False
print(is_palindrome("Never Odd or Even")) # Should be True
print(is_palindrome("abc")) # Should be False
print(is_palindrome("kayak")) # Should be True
倾其所爱 2025-02-18 19:33:36

您可以在不使用循环的情况下检查palindrome,

  1. 删除输入字符串中的所有白色空间。
  2. 将字符串转换为较低的情况。
  3. 比较字符串与其反向。
  4. 返回输出。
def is_palindrome(input_string):
    string = input_string.replace(" ", "").lower()
    rev_str = string[::-1]

    return string == rev_str

print(is_palindrome("Never Odd or Even"))
print(is_palindrome("abc"))
print(is_palindrome("kayak"))

输出:

True
False
True

You can check for palindrome without using loops

  1. Remove all white spaces in the input string.
  2. Convert the string to lower case.
  3. Compare the string with its reverse.
  4. return the output.
def is_palindrome(input_string):
    string = input_string.replace(" ", "").lower()
    rev_str = string[::-1]

    return string == rev_str

print(is_palindrome("Never Odd or Even"))
print(is_palindrome("abc"))
print(is_palindrome("kayak"))

output:

True
False
True
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文