题目描述
小鱼最近被要求参加一个数字游戏,要求它把看到的一串数字 aia_iai(长度不一定,以 000 结束),记住了然后反着念出来(表示结束的数字 000 就不要念出来了)。这对小鱼的那点记忆力来说实在是太难了,你也不想想小鱼的整个脑袋才多大,其中一部分还是好吃的肉!所以请你帮小鱼编程解决这个问题。
输入格式
一行内输入一串整数,以 000 结束,以空格间隔。
输出格式
一行内倒着输出这一串整数,以空格间隔。
输入输出样例
输入
3 65 23 5 34 1 30 0
输出
30 1 34 5 23 65 3
说明/提示
数据规模与约定
对于 100%100\%100% 的数据,保证 0≤ai≤231−10 \leq a_i \leq 2^{31} - 10≤ai≤231−1,数字个数不超过 100100100。
方式-直接反转
代码
def oi_input():
nums = list(map(int, input().split()))
return nums
def oi_test():
return [3, 65, 23, 5, 34, 1, 30, 0]
def solution(nums):
nums = nums[:-1]
print(' '.join(map(str, reversed(nums))))
if __name__ == '__main__':
nums = oi_test()
# prime_nums = oi_input()
solution(nums)
流程图
方式-模拟栈
代码
def oi_input():
nums = list(map(int, input().split()))
return nums
def oi_test():
return [3, 65, 23, 5, 34, 1, 30, 0]
def solution(nums):
'''
数组模拟栈
'''
nums, stack = nums[:-1], []
for i in nums:
stack.append(i)
while stack:
print(stack.pop(), end=" ")
if __name__ == '__main__':
nums = oi_test()
# prime_nums = oi_input()
solution(nums)
1859

被折叠的 条评论
为什么被折叠?



