当前位置: 代码迷 >> 综合 >> Codeup 1009-1012 python
  详细解决方案

Codeup 1009-1012 python

热度:70   发布时间:2024-03-06 22:30:16.0

1009: 财务管理

[命题人 : 外部导入]
时间限制 : 1.000 sec 内存限制 : 32 MB

题目描述
小明毕业一年了,并且找到了一份好工作。这一年里他赚了很多钱,现在他想知道他这一年里的平均月薪是多少,请你写一个程序帮他计算。
输入
输入包括12行。第i行为第i个月的实际月薪。(i=1,2,3…)
输出
输出小明的平均月薪,保留两位小数,并且最前面输出一个¥符号。
样例输入 Copy
100.00
489.12
12454.12
1234.10
823.05
109.20
5.27
1542.25
839.18
83.99
1295.01
1.75
样例输出 Copy
¥1581.42

sum = 0
pay = 0
for i in range(0,12):pay = float(input())sum += pay
avg = sum / 12
print("%.2f"%avg)

1010: 平均绩点

[命题人 : 外部导入]
时间限制 : 1.000 sec 内存限制 : 32 MB

题目描述
每门课的成绩分为A、B、C、D、F五个等级,为了计算平均绩点,规定A、B、C、D、F分别代表4分、3分、2分、1分、0分。
输入
有多组测试样例。每组输入数据占一行,由一个或多个大写字母组成,字母之间由空格分隔。
输出
每组输出结果占一行。如果输入的大写字母都在集合{A,B,C,D,F}中,则输出对应的平均绩点,结果保留两位小数。否则,输出“Unknown”。
样例输入 Copy
A B C D F
B F F C C A
D C E F
样例输出 Copy
2.00
1.83
Unknown

score = {
    'A' : 4,'B' : 3,'C' : 2,'D' : 1,'F' : 0
}
while True:sum = 0flag = 0s = input()for i in s.split():if i in score:sum += score[i]else:flag = 1breakif flag == 1:print('Unknown')else:avg = sum / len(s.split())print("%.2f"%avg)

1011: 软件版本

[命题人 : 外部导入]
时间限制 : 1.000 sec 内存限制 : 32 MB

题目描述
相信大家一定有过在网上下载软件而碰到多个不同版本的情况。一般来说,软件的版本号由三个部分组成,主版本号(Major Version Number),子版本号(Minor Version Number)和修订号(Revision_Number)。当软件进行了重大的修改时,主版本号加一;当软件在原有基础上增加部分功能时,主版本号不变,子版本号加一;当软件仅仅修正了部分bug时,主版本号和子版本号都不变,修正号加一。
在我们比较软件的两个版本的新旧时,都是先比较主版本号,当主版本号相同时再比较子版本号,前两者都相同的情况下再比较修正号。版本号越大的软件越新。
现在,小明在下载软件的时候碰到了两个版本,请你告诉他哪个版本更新一些。
输入
输入的第一行有一个整数T,代表有T组测试。接下来有T组测试。
每组测试分两行,第一行有三个整数代表第一个软件版本的主版本号,子版本号和修订号。第二行也有三个整数代表第二个软件版本的主版本号,子版本号和修订号。
数据中出现的整数都在[0,1000]范围之内。
输出
对于每组测试,如果第一个软件的版本新点,请输出First,如果第二个软件的版本新点,请输出Second,否则输出Same。
样例输入 Copy
3
1 1 0
1 1 1
1 1 1
1 1 0
1 1 1
1 1 1
样例输出 Copy
Second
First
Same

t = int(input())
for i in range(0,t):m = input().split()n = input().split()if m < n:print('Second')elif m == n:print('Same')else:print('First')

emmmmm1000 的时候是有问题的 但是我还没找到问题在哪

1012: 外币兑换

[命题人 : 外部导入]
时间限制 : 1.000 sec 内存限制 : 32 MB

题目描述
小明刚从美国回来,发现手上还有一些未用完的美金,于是想去银行兑换成人民币。可是听说最近人民币将会升值,并从金融机构得到了接下来十二个月可能的美元对人民币汇率,现在,小明想要在接下来一年中把美金都兑换成人民币,请问最多能得到多少人民币?
输入
输入的第一行是一个实数N(1.00<=N<=100.00),表示小明现有的美金数量。
接下来一行,包含12个实数ai,表示接下来十二个月的美元对人民币汇率。
输出
输出一个小数R,表示小明最多能获得的人民币数量,结果保留两位小数。
样例输入 Copy
46.91
6.31 6.32 6.61 6.65 5.55 5.63 6.82 6.42 6.40 5.62 6.78 5.60
样例输出 Copy
319.93

n = float(input())
lst = input().split()
lst.sort()
d = n * float(lst[11])
print("%.2f"%d)

1013: 摆积木

[命题人 : 外部导入]
时间限制 : 1.000 sec 内存限制 : 32 MB

题目描述
小明很喜欢玩积木。一天,他把许多积木块组成了好多高度不同的堆,每一堆都是一个摞一个的形式。然而此时,他又想把这些积木堆变成高度相同的。但是他很懒,他想移动最少的积木块来实现这一目标,你能帮助他吗?

输入
输入包含多组测试样例。每组测试样例包含一个正整数n,表示小明已经堆好的积木堆的个数。
接着下一行是n个正整数,表示每一个积木堆的高度h,每块积木高度为1。其中1<=n<=50,1<=h<=100。
测试数据保证积木总数能被积木堆数整除。
当n=0时,输入结束。
输出
对于每一组数据,输出将积木堆变成相同高度需要移动的最少积木块的数量。
在每组输出结果之间输出一个空行。
样例输入 Copy
6
5 2 4 1 7 5
0
样例输出 Copy
5

n = int(input())
while n != 0:lst = input().split()sum = 0cnt = len(lst)for i in range(0, cnt):sum += int(lst[i])avg = sum / cntsum1 = 0for i in range(0, cnt):if int(lst[i]) < avg:sum1 += (avg - int(lst[i]))else:sum1 += (int(lst[i]) - avg)res = sum1 / 2print(int(res))	n = int(input())