鱼C论坛

 找回密码
 立即注册
查看: 8840|回复: 29

[技术交流] Python:每日一题 121

[复制链接]
发表于 2017-11-6 20:37:23 | 显示全部楼层
  1. def foo(num):
  2.     while num >=10:
  3.         num = sum(map(int,list(str(num))))
  4.     return num

  5. list1 = [684, 6299800, 6041028, 2458660284, 937, 7857867, 384147026736, 888843160862, 270]
  6. dict1 = {v:k for k,v in zip(list(map(int,(list('123456789')))),[1, 6, 7, 4, 9, 3, 2, 5, 8])}
  7. d = {v:k for k,v in dict1.items()}
  8. x = [d[s] for s in sorted([dict1[r] for r in map(foo,list1)])]
  9. y = list(map(foo,list1))
  10. temp = list(zip(y,list1))
  11. result = []
  12. for i in x:
  13.     for each in range(len(temp)):
  14.         if i == temp[each][0]:
  15.             result.append(temp.pop(each)[1])
  16.             break

  17. result
  18. [937, 384147026736, 6299800, 684, 2458660284, 270, 6041028, 7857867, 888843160862]

复制代码


感觉写的有点麻烦

评分

参与人数 1鱼币 +3 收起 理由
冬雪雪冬 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-22 17:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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