鱼C论坛

 找回密码
 立即注册
123
返回列表 发新帖
楼主: zltzlt

[已解决]Python:每日一题 387

[复制链接]
发表于 2020-5-1 22:35:15 | 显示全部楼层
Twilight6 发表于 2020-5-1 22:20
嘿嘿 我可是自己想的,我没拿别人轮子用

sorted,str.count,严格来说都是轮子。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-1 22:40:13 | 显示全部楼层
  1. def P387(s):
  2.     dic = {}
  3.     n = []
  4.     for each in s:
  5.         dic[each] = s.count(each)
  6.     for i in dic:
  7.         n.append(dic.get(i))
  8.     while len(n) > 0:
  9.         for i in dic:
  10.             num = dic.get(i)
  11.             m = max(n)
  12.             if num == m:
  13.                 print(i*num,end='')
  14.                 del dic[i]
  15.                 n.remove(m)
  16.                 break

  17. s = input()
  18. P387(s)
复制代码

评分

参与人数 1荣誉 +4 鱼币 +4 收起 理由
zltzlt + 4 + 4

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 22:55:23 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 22:58:52 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 22:59:24 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 22:59:50 | 显示全部楼层
阴阳神万物主 发表于 2020-4-30 16:33
凑热闹.png
代码如下:

7 ms
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 23:02:47 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 23:04:02 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 23:05:02 | 显示全部楼层
harryfooty 发表于 2020-4-30 22:42
看完大佬们写的,不敢发了

没关系,一起进步~~~

用时 11 ms
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 23:05:37 | 显示全部楼层

输入示例 3 中的数据出错
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-1 23:06:50 | 显示全部楼层
永恒的蓝色梦想 发表于 2020-5-1 22:35
sorted,str.count,严格来说都是轮子。

嗷嗷 好吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 23:07:02 | 显示全部楼层

输入 'cccaaaccaa' 结果有误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-1 23:09:34 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-16 01:40:57 | 显示全部楼层
  1. def daily387(k="ccbcaaddddda"):

  2.     t = {}
  3.     str2 = ""
  4.     for j in k:
  5.         if j in t:
  6.             t[j] += 1
  7.         else:
  8.             t[j] = 1
  9.     t = sorted(t.items(), key=lambda x: x[1], reverse=True)
  10.     for a, b in t:
  11.         str2 += a * b
  12.     print(str2)

  13. daily387()
复制代码

python就不计较时间复杂度了,这个用C写,数组我写的时间复杂度(n^3),空间复杂度(3n)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-16 01:47:25 | 显示全部楼层

python底层很多都是C写的,sorted,count,index,find等等,其实你用python 循环也可以实现,
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-26 16:27:05 | 显示全部楼层
  1. def fun387(x):
  2.     set_x = list(set(x))
  3.     counter = sorted(list(set([x.count(i) for i in set_x])))[::-1]
  4.     result = ''
  5.     for i in counter:
  6.         for j in set_x:
  7.             if x.count(j) == i:
  8.                 result += j*i
  9.     return result
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-27 10:16:08 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-5-28 11:45:53 | 显示全部楼层
  1. def fun387(instr):
  2.     inlist = set(list(instr))
  3.     temp = []
  4.     for i in inlist:
  5.         temp.append((i, instr.count(i)))
  6.     temp.sort(key=lambda x:x[1], reverse=True)
  7.     result = ''
  8.     for i in temp:
  9.         result += i[0]*i[1]
  10.     return result
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-24 08:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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