|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
求助0基础学python分支与循环V的课后作业动动手第一题(https://fishc.com.cn/thread-164089-1-1.html)
回文数(正序(从左向右)和倒序(从右向左)读都是一样的整数)的判断,我用了笨办法一一核对,虽没标准答案那么巧妙,但有大佬能帮忙看看代码是否有漏洞吗?
谢谢。
huiwen = input("请输入数字:")
n = len(huiwen)
m = int(huiwen)
a = n // 2
for i in range(1,a+1):
if m // pow(10,n-1) == m % 10:
m = m % pow(10,n-1)
m = m // 10
n = n - 2
if i == a:
print(huiwen,"是回文数。")
else:
print(huiwen,"不是回文数。")
break
本帖最后由 isdkz 于 2023-3-17 16:38 编辑
你的代码基本上是正确的,但是有一些地方可以优化。
我将对你的代码进行简化和优化,如下所示:
- huiwen = input("请输入数字:")
- n = len(huiwen)
- m = int(huiwen)
- is_huiwen = True
- for i in range(n // 2):
- if huiwen[i] != huiwen[n - i - 1]:
- is_huiwen = False
- break
- if is_huiwen:
- print(huiwen, "是回文数。")
- else:
- print(huiwen, "不是回文数。")
复制代码
优化点如下:
在循环中,我们可以直接使用字符串的索引(huiwen[i])进行比较,而不是将其转换为整数。这使得代码更简洁。
我们引入了一个布尔变量 is_huiwen,用于在循环结束后确定输入的数字是否为回文数。这样,我们只需要在循环外部进行一次判断即可。
这个优化后的代码应该能够很好地处理回文数的判断。如果你有任何疑问,请随时提问。
|
|