解题思路:
因为需要每一个元素都为n/10,我们只需要先找到代价大的放入字典,且满足次数为n/10,只改变剩余的元素,代价之和就是最小的。
注意事项:
参考代码:
n=int(input())
a=[tuple(map(int,input().split())) for i in range(n)]
a.sort(key=lambda x:x[1],reverse=True)##以第二个元素排序,倒序
res={}
cnt=0
total=0
for i in range(n):
total+=a[i][1]##所有代价之和
if a[i][0] not in res:##不在字典里,就将其添加进去
res[a[i][0]]=0
if res[a[i][0]] <n/10:##因为需要每一个元素都为n/10,我们只需要先找到代价大的放入,剩余的代价之和就是最小的
res[a[i][0]]+=1
cnt+=a[i][1]
print(total-cnt)
0.0分
3 人评分
C语言程序设计教程(第三版)课后习题8.9 (C语言代码)浏览:822 |
C语言训练-求PI* (C语言代码)(正确结果竟然是谜一样的3.141591)浏览:1301 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:560 |
C二级辅导-进制转换 (C语言代码)浏览:514 |
A+B for Input-Output Practice (IV) (C语言代码)浏览:517 |
C语言训练-自由落体问题 (C语言代码)浏览:1738 |
ASCII帮了大忙浏览:749 |
简单的a+b (C语言代码)浏览:530 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:946 |
三角形 (C++代码)记忆化搜索浏览:1234 |