冬雪雪冬 发表于 2017-9-1 16:52:43

Python:每日一题 89(答题领鱼币)

有一个由数字组成的列表:

现在要把他们排序,要求按各位数字之和的大小,由小到大排序。结果为


我的解法:
**** Hidden Message *****

jerryxjr1220 发表于 2017-9-1 17:05:52

本帖最后由 jerryxjr1220 于 2017-9-1 17:08 编辑

num =
print(sorted(num, key=lambda n: sum(int(e) for e in str(n))))

solomonxian 发表于 2017-9-1 18:28:34

折腾sorted函数咯
def sum_sort(a):
    return sorted(a, key=lambda x: sum(int(i) for i in str(x)))

BngThea 发表于 2017-9-1 18:38:40

def sortlist(list1):
   result = sorted(list1, key = lambda x: sum(int(each) for each in str(x)))
   return result

瓦蓝 发表于 2017-9-1 18:41:22

学习学习

chunchun2017 发表于 2017-9-1 20:53:24

本帖最后由 chunchun2017 于 2017-9-1 20:55 编辑

大神们的代码一眼看不懂,来个笨一点的
list0 =
list1 = []
for i in list0:
    sum = 0
    for j in str(i):
      sum+=int(j)
    list1.append(sum)
dict0=dict(zip(list0,list1))
dict1=dict(sorted(dict0.items(),key=lambda item:item))
print(list(dict1.keys()))
======================
运行结果:
[1, 100, 4, 121, 400, 16, 25, 1024, 1600, 2401, 2500, 9, 36, 81, 144, 225, 324,
441, 900, 1521, 2025, 2304, 2601, 3600, 8100, 64, 361, 1225, 2116, 3025, 5041, 6
400, 49, 256, 625, 841, 1156, 1444, 2209, 2704, 3136, 3721, 4225, 4900, 6241, 16
9, 196, 484, 529, 961, 1681, 3364, 3481, 4624, 7225, 9025, 576, 729, 1089, 1296,
1764, 2916, 3249, 4356, 4761, 5184, 5625, 6084, 6561, 7056, 9216, 9801, 289, 67
6, 784, 1369, 1936, 2809, 3844, 4096, 5329, 6724, 7921, 8281, 9604, 1849, 5476,
7744, 8464, 9409, 4489, 5776, 5929, 7396, 8836, 3969, 7569, 8649, 6889]

wc365 发表于 2017-9-1 23:29:24

a =

#计算数字各位数字之和
def sumb(n):
    return n%10 + (n//10)%10 + (n//100)%10 + (n//1000)%10

#结合上面的sumb()函数,调整冒泡排序算法
def new_bubble_sort(lists):
    count = len(lists)
    for i in range(0,count):
      for j in range(i+1,count):
            if sumb(lists) > sumb(lists):
                lists, lists = lists, lists
    return lists

new_bubble_sort(a)
print(a)

木子枫 发表于 2017-9-2 01:16:13

刚学到第四课,来看看。。

ChrisYang 发表于 2017-9-4 16:52:28

本帖最后由 ChrisYang 于 2017-9-4 16:54 编辑

list1=
list2=

k=[]

for x in list2:
        t=0
        for xx in x:
                t+=int(xx)
        k.append(t)

list3=list(zip(k,list1))



list4=sorted(list3)

list5= for i in list4]
print(list5)
______________________________________
运行结果
   
>>> list5

>>>





张奥纳多.益达 发表于 2017-9-5 20:18:33

懵逼

schweinfan 发表于 2017-9-7 22:04:44

看下答案

樱花冷雨 发表于 2017-9-8 11:26:06

学习学习{:5_109:}

li7223938 发表于 2017-9-26 20:53:05

学习一下

li7223938 发表于 2017-9-26 20:53:55

学习学习

wangling 发表于 2017-11-1 18:08:15

没做对{:5_98:}

python~ 发表于 2017-11-4 21:26:46

python~ 发表于 2017-11-4 21:27:36

本帖隐藏的内容

def sum1(num):
    s = 0
    while num:
      s += num % 10
      num //= 10
    return s

list1 =
list1.sort(key = sum1)
print(list1)

shigure_takimi 发表于 2017-12-2 02:27:01

lst =

def order(lst):
    return sorted(lst, key = lambda number: sum(int(i) for i in str(number)))

print(order(lst))
   

>>> ================================ RESTART ================================
>>>

yjsx86 发表于 2018-1-29 19:20:13

L =

def calc(n):
    rs = 0
    while n>0:
      n,rem = divmod(n,10)
      rs += rem
    return rs

print(sorted(L,key=calc))

Tianjun 发表于 2018-1-30 09:43:30

我刚学,我觉得把数组中第一第二个进行比较,再第二第三个进行比较。。。如此换位就成功啦
页: [1] 2
查看完整版本: Python:每日一题 89(答题领鱼币)