蓝桥杯之数列排序问题python实现
题目
问题描述
给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
第一行为一个整数n。
第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式
输出一行,按从小到大的顺序输出排序后的数列。
样例输入
5
8 3 6 4 9
样例输出
3 4 6 8 9
代码
loop = int(input())
a = list(map(int,input().split()))
a.sort()
for i in a:
if loop == 1:
print('',end=str(i))
break
print(str(i),end=' ')
loop -=1
首先,代码没什么难度都能看懂,但是呢,做题的时候我们可能感觉对了但机器判定的时候还是不对。读者可能会问了,为什么要在for循环中输出的时候加上一个if判断,很简单,就是为了剔除最后一个字符后面加上的空格。如果说加上这个空格的话,看上去和题目给的输出是一样的,但是呢,细节就在于,题目给的输出,9后面是没有空格的。如果没有if,那么我们输出的最后一个字符后面就会有空格,这道题自然就是不对的。这个请大家都注意一下。