Python 官网:https://www.python.org/
-
Free:大咖免费“圣经”教程《 python 完全自学教程》,不仅仅是基础那么简单……
自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
—— 华罗庚
![等风来,不如追风去……](https://i-blog.csdnimg.cn/blog_migrate/4a8b43fa255f3b54c491f1a1b49b890d.jpeg)
题目描述:
给你两个字符串S、T,让你从S中剪下字符组成T,问是否可行。
算法解析:
- 1、如果能剪拼成,t的字符一定全在s中,首先用集合判定。如有not set(t) < set(s)的情形,直接False。
if not set(t) < set(s):
return False # 用集合判定最好情形。
- 2、遍历t,在s中找字符并取出,如不在,return False。
- 3、完成遍历t,代码全部执行完成,返回True。
常规算法:借助列表
代码
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")
我的HOT博:
- 给定字符串提取姓名(字符串、list、re“零宽断言”)(1051阅读)
- 我的 Python.color() (Python 色彩打印控制)(1125阅读)
- python清屏(1290阅读)
- 回车符、换行符和回车换行符(1322阅读)
- Linux 脚本文件第一行的特殊注释符(井号和感叹号组合)的含义(1171阅读)
- pandas 数据类型之 Series(1224阅读)
- 聊天消息敏感词屏蔽系统(字符串替换 str.replace(str1, *) )(1270阅读)
- 练习:银行复利计算(用 for 循环解一道初中小题)(1188阅读)
- pandas 数据类型之 DataFrame(2136阅读)
- :班里有人和我同生日难吗?(蒙特卡洛随机模拟法)(2180阅读)
- Python字符串居中显示(2359阅读)
- 练习:求偶数和、阈值分割和求差( list 对象的两个基础小题)(1665阅读)
- 用 pandas 解一道小题(2007阅读)
- 可迭代对象和四个函数(1083阅读)
- “快乐数”判断(1252阅读)
- 罗马数字转换器(构造元素取模)(2159阅读)
- Hot:罗马数字(转换器|罗生成器)(4750阅读)
- Hot:让QQ群昵称色变的代码(36654阅读)
- Hot:斐波那契数列(递归| for )(4071阅读)
- 柱状图中最大矩形(1663阅读)
- 排序数组元素的重复起止(1258阅读)
- 电话拨号键盘字母组合(1402阅读)
- 密码强度检测器(1986阅读)
- 求列表平衡点(1837阅读)
- Hot: 字符串统计(4308阅读)
- Hot:尼姆游戏(聪明版首发)(3493阅读)尼姆游戏(优化版)(1175阅读)
推荐条件 点阅破千
回目录
精品文章:
- 好文力荐:《python 完全自学教程》齐伟书稿免费连载
- OPP三大特性:封装中的property
- 通过内置对象理解python'
- 正则表达式
- python中“*”的作用
- Python 完全自学手册
- 海象运算符
- Python中的 `!=`与`is not`不同
- 学习编程的正确方法
来源:老齐教室
回目录
Python 入门指南【Python 3.6.3】
好文力荐:
-
全栈领域优质创作者——寒佬(还是国内某高校学生)好文:《非技术文—关于英语和如何正确的提问》,“英语”和“会提问”是学习的两大利器。
CSDN实用技巧博文: