Python 官网:https://www.python.org/
自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
—— 华罗庚
题目描述:
给你两个字符串S、T,让你从S中剪下字符组成T,问是否可行。

算法解析:
if not set(t) < set(s):
return False # 用集合判定最好情形。
常规算法:借助列表
代码
def istext(s, t):
''' 判定从s中剪出字符组成t '''
s, t = list(s), list(t) # 鉴于字符串s.replace('', s)方法会从字符串中清除所有重复的字符,将字符转成list操作。
for i in t:
if i in s:
s.remove(i) # list.remove()方法默认删除index最小的一个元素。
else:
return False
return True
另类算法:借助字典
代码
def istext(s, t):
''' 判定从s中剪出字符组成t '''
t_dict = {} # 初始化t字符数统计字典。
for i in t: # 遍历t统计字符数。
t_dict[i] = t.count(i)
for i in t_dict.keys(): # 也可以,in t_dict,直接遍历字典默认遍历键值。遍历t字符统计字典,比对s中有无足够字符。
if s.count(i) < t_dict.get(i):
return False
return True
代码运行效果截屏图片

mypycolor完整源码(源码较长,点此跳过源码)
#!/sur/bin/nve python
# coding: utf-8
'''
Tille = '拼接子字符串'
Author = '梦幻精灵_cq'
Date = '2022-11-6'
'''
s, t = 'AbcdFcgcfhhhgcffgGDXJ', 'bAhhhgg'
def istext(s, t):
''' 判定从s中剪出字符组成t '''
if not set(t) < set(s):
return False # 用集合判定最好情形。
t_dict = {} # 初始化t字符数统计字典。
for i in t: # 遍历t统计字符数。
t_dict[i] = t.count(i)
for i in t_dict.keys(): # 也可以,in t_dict,直接遍历字典默认遍历键值。遍历t字符统计字典,比对s中有无足够字符。
if s.count(i) < t_dict.get(i):
return False
return True
def istext(s, t):
''' 判定从s中剪出字符组成t '''
if not set(t) < set(s):
return False # 用集合判定最好情形。
s, t = list(s), list(t) # 鉴于字符串s.replace('', s)方法会从字符串中清除所有重复的字符,将字符转成list操作。
for i in t:
if i in s:
s.remove(i) # list.remove()方法默认删除index最小的一个元素。
else:
return False
return True
if __name__ == '__main__':
print(f"\n字符串:\n{'':>6}S: {s}\n{'':>6}T: {t}\n{'~'*50}\n\n{'':>6}可以从S剪下字符组成T:{istext(s, t)}\n\n{'~'*50}\n")
来源:老齐教室
全栈领域优质创作者——寒佬(还是国内某高校学生)好文:《非技术文—关于英语和如何正确的提问》,“英语”和“会提问”是学习的两大利器。