鱼C论坛

 找回密码
 立即注册
查看: 2223|回复: 3

学校的一道问题求助

[复制链接]
发表于 2020-11-20 16:13:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
给定n个整数,请计算每个整数各位数字和,按各位数字和从大到小的顺序输出。
输入格式  

  输入的第一行包含一个整数n,表示给定数字的个数。第二行包含n个整数,相邻的整数之间用一个空格分隔,表示所给定的整数。
输出格式  


  输出多行,每行包含两个整数,分别表示一个给定的整数和它的各位数字和。按各位数字和递减的顺序输出。如果两个整数各位数字和相同,则先输出值较小的,然后输出值较大的。
样例输入
5
101 100 999 1234 110

样例输出
999 27
1234 10
101 2
110 2
100 1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-20 16:43:18 | 显示全部楼层

参考代码:
count = int(input())
numbers = input().split()
result = []
for i in numbers:
    temp = [i]
    temp.append(sum([int(j) for j in i]))
    result.append(temp)
for i in sorted(result,key=lambda x:x[1],reverse=True):
    print(i[0],i[1])
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-20 23:35:24 | 显示全部楼层
n = input()
data = input().split()
list1 = [[int(i), sum(map(int, i))]  for i in data]
list1.sort(key = lambda x: x[1], reverse = True)
for i in list1:
    print(i[0], i[1])
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-21 10:01:42 | 显示全部楼层
#!/usr/bin/env python3
#coding=utf-8

# count = int(input())
# array = input().split()
array = ['999', '1234', '110', '101', '100', '010', '001', '1234']

# 第一遍排自身各个位上的数 的和
result = []
for i in array:
    result.append([int(i), sum([int(j) for j in i])])

print(result)
result.sort(key=lambda x:x[1], reverse=True)
print(result)
# 第二遍排自身
count = 0
for i in range(len(result)-1):
    if result[i][1] == result[i+1][1]:
        count += 1
    else:
        if count != 0:
            result[i-count:i+count] = sorted(result[i-count:i+count])
            count = 0

# 退出后尾部有相等
if count != 0:
    i, count = i+1, count+1
    result[i-count+1:i+count] = sorted(result[i-count+1:i+count])

for i in result: print(i)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-17 13:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表