鱼C论坛

 找回密码
 立即注册
查看: 3794|回复: 57

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

[复制链接]
发表于 2020-4-30 13:30:45 | 显示全部楼层 |阅读模式

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

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

x
今天的题目:


给定一个字符串,将字符串里的字符按照出现的次数降序排列,并返回排列后的字符串。

示例 1:

输入:"tree"
输出:"eert"
解释:'e' 出现两次,'r' 和 't' 都只出现一次。因此 'e' 必须出现在 'r' 和 't' 之前。
说明:此外,"eetr" 也是正确的答案。
示例 2:

输入:"cccaaa"
输出:"cccaaa"
解释:'c' 和 'a' 都出现三次。
说明:此外,"aaaccc" 也是有效的答案。
注意:"cacaca"是不正确的,因为相同的字母必须放在一起。
示例 3:

输入:"Aabb"
输出:"bbAa"
说明:此外,"bbaA" 也是正确的答案,但 "Aabb" 是不正确的。


欢迎大家一起答题!
最佳答案
2020-4-30 16:52:47
def f387(s:str):
    from collections import Counter
    r = [i for i in Counter(s).most_common()]
    return ''.join(i*j for i,j in r)

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2020-4-30 13:31:25 | 显示全部楼层
占楼
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-30 13:36:06 | 显示全部楼层
class Solution:
    def frequencySort(self, s: str) -> str:
        s=sorted(s)
        s.sort(key=collections.Counter(s).get,reverse=True)
        return ''.join(s)

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 13:36:47 | 显示全部楼层
本帖最后由 sunrise085 于 2020-4-30 14:07 编辑
def fun387(string):
    result=''
    myset=set(string)
    mylist=[]
    for ch in myset:
        mylist.append(([ch,string.count(ch)]))
    
    mylist.sort(key=lambda ele:ele[1],reverse=True)
    for list1 in mylist:
        result+=list1[0]*list1[1]
    return result

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 14:00:49 | 显示全部楼层
from collections import Counter
def f387(s):
    res,l = '',sorted(list(Counter(s).items()),reverse=True,key=lambda i: i[1])
    for i in l:
        res += i[0]*i[1]
    return res

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 14:03:14 | 显示全部楼层
本帖最后由 Twilight6 于 2020-4-30 14:56 编辑
string = input('请输入一个字符串~:')
set_str = set(string)
count_dict = {}
for i in set_str:
    count_dict[i] = string.count(i)
new_count_list = sorted(list(zip(count_dict.keys(),count_dict.values())),key=lambda x:x[1])
for i in new_count_list[::-1]:
    print(i[0]*i[1],end='')

唉,我怎么感觉只会写暴力的

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 14:06:45 | 显示全部楼层
from collections import Counter
def f387(s):
    return ''.join([i[0]*i[1] for i in sorted(list(Counter(s).items()),reverse=True,key=lambda i: i[1])])

评分

参与人数 1鱼币 +1 收起 理由
zltzlt + 1 一样的速度

查看全部评分

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

使用道具 举报

发表于 2020-4-30 14:11:33 | 显示全部楼层
def func(string):
    list1 = [i for i in string]
    list1.sort(key = lambda x: (string.count(x), x), reverse = True)
    return ''.join(list1)

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 14:19:33 | 显示全部楼层
本帖最后由 March2615 于 2020-4-30 15:07 编辑
def daily387(s):
    return ''.join(k * v for k, v in Counter(s).most_common())

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 14:30:13 | 显示全部楼层
后排
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-30 14:30:45 | 显示全部楼层
本帖最后由 悠悠2264 于 2020-4-30 20:19 编辑
def fun387(s):
    result = ''
    d = {}
    for i in s:
        try:
            d[i] = d[i] + 1
        except:
            d[i] = 1
    for c in range(len(s)):
        t = None
        for i in d:
            t = i if t == None or d[t] < d[i] else t  
        for p in range(d[t]):
            result = result + t
        d[t] = 0
    return result

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 14:43:19 | 显示全部楼层
def reverse_sort(string):
    return_str = ""
    length = len(set(string))
    zero = [0 for i in range(length)]
    str_dict = dict(zip(set(string), zero))
    for each in string:
        str_dict[each] += 1
    sorted_str = sorted(str_dict.items(), key=lambda item:item[1], reverse=True)
    for each in sorted_str:
        for i in range(each[1]):
            return_str += each[0]
    return return_str

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 15:06:27 | 显示全部楼层
本帖最后由 qiuyouzhi 于 2020-4-30 16:33 编辑

随便写写
def func(str1):
    return ''.join(sorted(str1, key = lambda c: str1.count(c), reverse = True))
改一下:
func = lambda str1: ''.join(sorted(str1, key = lambda c: str1.count(c), reverse = True))

评分

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

查看全部评分

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

使用道具 举报

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

使用道具 举报

发表于 2020-4-30 15:37:27 | 显示全部楼层
def timu387(s):
    if s.strip() == '':
        return ''
    sa = set(s)
    ra=''
    da = {}
    for i in sa:
        da[i] = s.count(i)
    la = sorted(da.items(), key=lambda x: x[1], reverse=True)
    for ik,iv in la:
        ra = ra+ik*iv
    return ra
print(timu387('tree'))
print(timu387('cccaaa'))
print(timu387('Aabb'))

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 15:40:10 | 显示全部楼层
def f387(s):
    sc = sorted(Counter(s).items(), key = lambda x: x[1], reverse=True)
    return ''.join(val * c for val, c in sc)

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 16:10:42 | 显示全部楼层
def f387(s):
    tmp = set(s)
    letter = list(tmp)
    num = []
    for i in letter:
        num.append(s.count(i))
    res = ""
    for i in range(len(letter)) :
        max_index = num.index(max(num))
        res += num.pop(max_index) * letter.pop(max_index)
    return res

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 16:33:15 | 显示全部楼层
凑热闹.png
代码如下:
def solve(s:str)->str:
    d = {x:s.count(x) for x in set(s)}
    return ''.join([x*d[x] for x in sorted(d.keys(),key=lambda a:d[a],reverse=1)])

if __name__ == '__main__':
    print('示例1 输出:',solve("tree"))
    print('示例2 输出:',solve("cccaaa"))
    print('示例3 输出:',solve("Aabb"))

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-30 16:52:15 | 显示全部楼层

我给忘了在哪看到的了
里面讲的就是找最多最少字符,出现次数前几的字符,就用那个most_common()
本来想用sorted,但是我的reverse参数不知道为什么不能设置切片又不好看,甚至能找到错误答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-30 16:52:47 | 显示全部楼层    本楼为最佳答案   
def f387(s:str):
    from collections import Counter
    r = [i for i in Counter(s).most_common()]
    return ''.join(i*j for i,j in r)

评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-21 00:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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