编写函数isPalindrome(n ) ;参数n是一个正整数判断该数是否为回文数,若是返回True,否则返回False。编写主程序测试函数功能是否正确。 回文数:123454321
时间: 2024-05-29 14:09:36 浏览: 54
def isPalindrome(n):
s = str(n)
return s == s[::-1]
# 测试函数
print(isPalindrome(123454321)) # True
print(isPalindrome(12321)) # True
print(isPalindrome(123321)) # True
print(isPalindrome(12345)) # False
相关问题
编写函数isPalindrome(n ) ;参数n是一个正整数判断该数是否为回文数,若是返回True,否则返回False
def isPalindrome(n):
# 将n转换为字符串
str_n = str(n)
# 判断字符串是否与其反转后的字符串相等
if str_n == str_n[::-1]:
return True
else:
return False
编写函数isPalindrome(n ) ;参数n是一个正整数判断该数是否为回文数,若是返回True,否则返回False。编写主程序测试函数功能是否正确。
### 回答1:
以下是Python代码实现:
```python
def isPalindrome(n):
s = str(n)
return s == s[::-1]
# 测试函数
print(isPalindrome(12321)) # True
print(isPalindrome(12345)) # False
```
解释:
1. `str(n)`将整数n转换为字符串s;
2. `s[::-1]`将字符串s翻转,然后返回;
3. `s == s[::-1]`比较翻转前后的字符串是否相等,若相等则返回True,否则返回False。
### 回答2:
要编写一个判断一个正整数是否为回文数的函数isPalindrome(n),首先需要将正整数n转换成字符串,然后利用字符串的切片操作来反转字符串。接着,比较原始字符串n和反转后的字符串是否相等,若相等则为回文数,返回True;否则,不是回文数,返回False。
代码如下:
def isPalindrome(n):
str_n = str(n) # 将正整数n转换成字符串
reversed_n = str_n[::-1] # 利用切片操作反转字符串
if str_n == reversed_n: # 比较原始字符串n和反转后的字符串是否相等
return True
else:
return False
# 主程序测试函数isPalindrome的功能是否正确
n1 = 12321
n2 = 12345
print(isPalindrome(n1)) # 输出结果为True
print(isPalindrome(n2)) # 输出结果为False
在主程序中,我定义了两个测试用例n1和n2,分别是一个回文数12321和一个非回文数12345。然后,分别调用函数isPalindrome,通过打印输出结果来验证函数的功能是否正确。
输出结果如下:
True
False
说明函数isPalindrome的功能是正确的,能够正确判断一个正整数是否为回文数。
### 回答3:
要编写一个函数isPalindrome(n),该函数的参数是一个正整数n,用于判断这个数是否是一个回文数。如果是回文数,则返回True,否则返回False。下面是对该函数的编写和主程序的测试:
```python
def isPalindrome(n):
# 将数字转换为字符串,方便处理
num_str = str(n)
# 判断字符串的长度是否大于1
if len(num_str) > 1:
# 判断字符串是否与其反转后的字符串相等
if num_str == num_str[::-1]:
return True
else:
return False
else:
return True
# 测试函数功能是否正确
if __name__ == "__main__":
test_cases = [121, 12321, 12345, 1, 11, 123321]
expected_results = [True, True, False, True, True, True]
for i, test_case in enumerate(test_cases):
result = isPalindrome(test_case)
if result == expected_results[i]:
print(f"Test case {i+1}: Passed")
else:
print(f"Test case {i+1}: Failed")
```
在上述代码中,函数isPalindrome首先将参数n转换为字符串,然后判断字符串的长度是否大于1。如果大于1,则判断字符串是否与其反转后的字符串相等,如果相等则说明是回文数,返回True;否则返回False。
主程序中定义了一些测试用例和对应的期望结果,然后使用for循环对每个测试用例进行测试,并比较得到的结果与期望结果是否一致,输出相应的提示信息以表示测试通过与否。
以上是对函数的编写和主程序的测试的回答,希望能对你有帮助。
阅读全文