蓝桥杯:景点游览里面对Python来说的一个坑点
题目
- 问题描述
小明来到一个景区游玩,但是他的时间有限,没办法逛遍所有的景点,所以他从网上下载了每个景点的评分,他希望能够使游览的景点的评分总和最高,于是他希望你帮他对于N个景点排下序。 - 输入格式
输入的第一行包含一个正整数N,表示N个景点。
第二行有N个正整数,表示每个景点的评分值。 - 输出格式
输出一行,包含N个正整数,表示N个景点的评分从大到小的排列 - 样例输入
4
3 2 4 1 - 样例输出
4 3 2 1 - 数据规模和约定
N<=1000,每个景点的评分<=10000。
这题目对C++、C、Java来说可能是没有问题,写好排序算法就能过
但是这里对Python有一个坑点
一开始的代码:
#从大到小排序
n=int(input())
l=list(map(int,input().split(" ")))
l=sorted(l,reverse=True)
for i in l:
print(int(i),end=" ")
运行错误。
我就觉得可能它是一个字符串输入的。因为前面有很多题都有这个坑
#从大到小排序
n=int(input())
l=list(map(str,input().split(" ")))
for i in range(len(l)):
l[i]=int(l[i])
l=sorted(l,reverse=True)
for i in l:
print(int(i),end=" ")
还是不对,办法我只能调试看看哪里出问题了
一顿操作之后发现,这个数据后面有一个空字符串
就是这个字符串让我的排序发生错误
谁也没想到数据的最后添了一个空格
用pop()删除这个元素即可,pop()是默认删除最后一个元素的方法
#从大到小排序
n=int(input())
l=list(map(str,input().split(" ")))
l.pop()
for i in range(len(l)):
l[i]=int(l[i])
l=sorted(l,reverse=True)
for i in l:
print(int(i),end=" ")
over
本文来自博客园,作者:{Zeker62},转载请注明原文链接:https://www.cnblogs.com/Zeker62/p/15046283.html