123321 是一个非常特殊的数,从左边读和从右边读是一样的,称这样的数次日文致。输人一个正整数n(1≤n≤54),编程求各位数字之和等于n的5位和6位十进制回文数按从小到大的顺序输出满足条件的整数。如果输入的数不在指定的范围,输出“输入错误,请重新输入!”如果没有各位之和与输入的数相等的5位和6位回文数,输出“无满足条件的数”
时间: 2024-02-19 15:58:15 浏览: 82
以下是Python代码实现:
```python
def is_palindrome(n):
return str(n) == str(n)[::-1]
n = int(input())
if n < 1 or n > 54:
print("输入错误,请重新输入!")
else:
found = False
for i in range(10000, 100000):
if is_palindrome(i) and is_palindrome(i*11):
digits_sum = sum([int(d) for d in str(i)])
if digits_sum == n:
print(i)
found = True
for i in range(100000, 1000000):
if is_palindrome(i) and is_palindrome(i//10):
digits_sum = sum([int(d) for d in str(i)])
if digits_sum == n:
print(i)
found = True
if not found:
print("无满足条件的数")
```
输入样例:
```
8
```
输出样例:
```
51815
81918
```
阅读全文