如何解决编写一个python程序来反转给定的数字
输入=12345 输出=54321
写数字反转的程序
n=int(input("Enter number :"))
rev=0
while(n>0):
dig = n%10
rev=rev*10+dig
n=n//10
print("The reverse of the number:",rev)
可以解释为什么这个打印 54321
解决方法
你可以在 python 中迭代一个字符串,你将迭代每个字符
你去吧:
a = input("Enter : ")
x = [num for num in a] # Getting the individual digits
b = reversed(x) # reversed() is a built in function
print("".join(b))
,
这个就简单多了
inp = input("Enter the number")
list1 = [numbers for numbers in inp]
list2 = [reversed_numbers for reversed_numbers in list1[::-1]]
print("".join(list2))
,
这应该有效
number = int(input("Enter a number: "))
rev = ''
while number > 0:
last_digit = number % 10 #The remainder when it's divided by 10 will always be the last digit
rev = rev + str(last_digit)
number = number // 10
print("Reversed : ",rev)
,
让,n = 12345,其中 12345 是给定的输入。
rev = 0
Now in the first iteration of the while loop n > 0
dig = remainder of n divided by 10,So it is = 5
rev = rev(0) * 10 + dig(5) = 5
n = n // 10 = 1234
在第二次迭代中 n = 1234,即 > 0
rev = 5
dig = remainder of n divided by 10,So it is = 4
rev = rev(5) * 10 + dig(4) = 54
n = n // 10 = 123
在第三次迭代中 n = 123,即 > 0
rev = 54
dig = remainder of n divided by 10,So it is = 3
rev = rev(54) * 10 + dig(3) = 543
n = n // 10 = 12
在第四次迭代中 n = 12 即 > 0
rev = 543
dig = remainder of n divided by 10,So it is = 2
rev = rev(543) * 10 + dig(2) = 5432
n = n // 10 = 1
在第五次迭代中 n = 1 即 > 0
rev = 5432
dig = remainder of n divided by 10,So it is = 1
rev = rev(5432) * 10 + dig(1) = 54321
n = n // 10 = 0
现在在 while 循环的第六次迭代中 n = 0 所以它不大于 0 所以循环会中断并且你得到 rev = 54321
,其实很简单
第一次迭代
- 好吧,您首先得到 10 的 %,这基本上是最后一个数字(残差)dig = 5,
- 然后将其添加到 rev*10(在第一次迭代 0 中)+ dig = 5,
- 你整个 nuber 将 n 除以 10(删除最后一个 nuber)n = 1234
第二次迭代
- 挖掘 = 4
- 转数 =5*10 + 4 = 54
- n = 123
第三次迭代
- 挖掘 = 3
- 转数 = 540 + 3 = 543
- n = 12
...
然而,有更简单的方法来做到这一点,例如。
如果你的输入是字符串,那么你只需要反转它
input = "12345"
output = input[::-1]
如果输入是数字(整数,浮点数),则必须将其转换为字符串
input = 12345
output = str(input)[::-1]
然后转换回来
int(output)
,
查看其他答案以获得很好的解释。在这里,我为原始问题添加了 2 个更简单的解决方案 - 如何反转数字:
# For example,12345:
num = input("Enter number: ")
# fastest and shortest:
rev = num[::-1]
# or (slower and longer)
rev = "".join(reversed(num))
print(f"The reverse of the number: {rev}")
# The reverse of the number: 54321
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。