鱼C论坛

 找回密码
 立即注册
查看: 3152|回复: 56

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

[复制链接]
发表于 2020-4-2 17:50:20 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 zltzlt 于 2020-4-2 17:54 编辑

今天的题目:


给定字符串 S 和 T,它们只包含小写字符。在 S 中,所有字符只会出现一次

S 已经根据某种规则进行了排序。我们要根据 S 中的字符顺序对 T 进行排序。

更具体地说,如果 S 中 x 在 y 之前出现,那么返回的字符串中 x 也应出现在 y 之前。

返回任意一种符合条件的对 T 排序后的字符串。

示例:

输入:S = "cba", T = "abcd"
输出:"cbad"
解释:S 中出现了字符 "a", "b", "c",所以 "a", "b", "c" 的顺序应该是 "c", "b", "a" 。
由于 "d" 没有在 S 中出现,它可以放在 T 的任意位置。"dcba", "cdba", "cbda" 都是正确的答案。


欢迎大家一起答题!
最佳答案
2020-4-2 18:39:21
def solve(S,T):
    string = ''
    for i in S:
        string += i*T.count(i
                            )
        T=T.replace(i,'')
    return string+T

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2020-4-2 17:56:47 | 显示全部楼层
本帖最后由 TJBEST 于 2020-4-2 20:03 编辑

先来一个
def fun367(S,T):
    def inner(element):
        try:
            return S.index(element)
        except Exception:
            return 100
    T_arr = list(T)
    T_arr.sort(key = inner)
    result = ''
    for each in T_arr:
        result += each
    return result
再来一个 ,您测测 不知道哪个更快,如果您测完了 请写两个测试时间 我最近想研究一下 python的内置函数算法 以便优化。
def fun367(S,T):
    def inner(element):
        try:
            return S.index(element[0])
        except Exception:
            return 100
    dic = {}
    for each in T:
        try:
            dic[each] += 1
        except Exception:
            dic[each] = 1
    item = list(dic.items())
    item.sort(key = inner)
    result = ''
    for each in item:
        result += each[0]*each[1]
    return result

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 18:16:59 | 显示全部楼层
def test(S, T):
    def idx(x):
        try:
            index = S.index(x)
        except:
            index = 99
        return index
    return ''.join(sorted(T, key=idx))
奇奇怪怪的

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 18:30:24 | 显示全部楼层
本帖最后由 永恒的蓝色梦想 于 2020-4-2 18:40 编辑

垃圾方法
class Solution:
    def customSortString(self, S: str, T: str) -> str:
        d={j:i for i,j in enumerate(S)}
        return ''.join(sorted(T,key=lambda v:d.get(v,-1)))

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 18:39:21 | 显示全部楼层    本楼为最佳答案   
def solve(S,T):
    string = ''
    for i in S:
        string += i*T.count(i
                            )
        T=T.replace(i,'')
    return string+T

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 18:47:10 | 显示全部楼层
本帖最后由 kinkon 于 2020-4-2 20:21 编辑

试试这样行不行
def f367(S, T):
    tmp_S = set(S) & set(T)
    s = ''
    for i in S:
        if i in tmp_S:
            s += i * T.count(i)
            T = T.replace(i,'')
    return s + ''.join(T)

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 18:48:09 | 显示全部楼层
TJBEST 发表于 2020-4-2 17:56
先来一个

再来一个 ,您测测 不知道哪个更快,如果您测完了 请写两个测试时间 我最近想研究一下 python ...

冒昧的提个意见

如果追求效率的话
    def inner(element):
        if element[0] in S:
            return S.index(element[0])
        else:
            return 100
这段代码每执行一次,就会遍历两次(不一定完全遍历)S,拉低效率。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-2 19:31:30 | 显示全部楼层
def str_sort(s, t):
    sort_dict = {}
    sorted_str = ""
    for letter in t:
        if letter not in sort_dict:
            sort_dict[letter] = 0
        sort_dict[letter] += 1
    for each_letter in s:
        if each_letter in sort_dict:
            for i in range(sort_dict[each_letter]):
                sorted_str += each_letter
            del sort_dict[each_letter]
    for item in sort_dict:
        for j in range(sort_dict[item]):
            sorted_str += item
    return sorted_str

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 20:01:05 | 显示全部楼层
本帖最后由 TJBEST 于 2020-4-2 20:04 编辑
永恒的蓝色梦想 发表于 2020-4-2 18:48
冒昧的提个意见

如果追求效率的话这段代码每执行一次,就会遍历两次(不一定完全遍历)S,拉低效率。


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

使用道具 举报

发表于 2020-4-2 20:26:00 | 显示全部楼层
def a367(s,t):
    a, b = list(s), list(t)
    for i in a:
        if i in b:
            b.remove(i)
            b.append(i)
    print(''.join(b))
a367('cba','abcd')

字符串的方法掌握的不好先,转化成列表做吧

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 20:50:33 | 显示全部楼层
def f(s,t):
    d = {}
    for each in t:
        if each in d.keys():
            d[each] += 1
        else:
            d.setdefault(each,1)
    t1 = ''
    for each in s:
        if each in d.keys():
            t1 += each * d[each]
            del d[each]
    for n in d.keys():
        t1 += n * d[n]
    return t1

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 21:05:10 | 显示全部楼层
def q367(S,T):
    dict_S = dict()
    for each in S:
        dict_S[each] = 0

    new_T = ''
    for each in T:
        if each in dict_S:
            dict_S[each] += 1
        else:
            new_T += each

    new_S = ''
    for each in S:
        new_S += each*dict_S[each]

    return new_S + new_T

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 21:20:36 | 显示全部楼层
def customSortString_2(S: str, T: str) -> str:
    dict_T = {}
    for each in T:
        dict_T[each] = dict_T.setdefault(each, 0) + 1
    result = []
    for ch in S:
        if ch in T:
            result.append(ch * dict_T[ch])
    for ch in T:
        if ch not in S:
            result.append(ch)
    return ''.join(result)

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 21:50:20 | 显示全部楼层
那问一下如果S='cba',T='abcdac'则答案是什么?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-2 21:59:22 | 显示全部楼层
能一行代码解决的问题坚决不用两行,但效率可能会低点
def f367(S, T):
    return ''.join([i*T.count(i) for i in S])+''.join([i for i in T if i not in S])

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 22:02:02 | 显示全部楼层
def fun367(S,T):
    dic={i:T.count(i) for i in set(T)}
    result=''
    for i in S:
        if i in dic:
            result+=i*dic[i]
            dic.pop(i)
    for k,v in dic.items():
        result+=k*v
    return result

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 22:25:46 | 显示全部楼层
def func367(S,T):
    res = ''
    for each in S:
       if each in T:
           res += each * T.count(each)
           T = T.replace(each,'')
    return res+T

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 22:56:08 | 显示全部楼层
def f367(s,t):
    dict_s_index = {}
    for index,string in enumerate(s):
        dict_s_index[string] = index
    dict_t={}
    for i in t:
        dict_t[i]=dict_t.get(i,0)+1
    t_str=''
    for i in dict_s_index:
        if i in dict_t.keys():
            t_str+=dict_t[i]*i
        else:
            continue
    for j in dict_t:
        if j not in dict_s_index.keys():
            t_str+=dict_t[j]*j
    return t_str

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 23:44:56 | 显示全部楼层
def fun367(S, T):
    return ''.join(sorted(T, key=S.find))

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-4-2 23:48:51 | 显示全部楼层
本帖最后由 十月故里 于 2020-4-2 23:56 编辑
s=input()
t=input()
a=s
for i in a:
    if i not in t:
        s=s.replace(i,'')
    else:
        num=t.count(i)
        t=t.replace(i,'')
        s=s.replace(i,i*num)
        
print(s+t)

评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-28 01:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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