鱼C论坛

 找回密码
 立即注册
查看: 2328|回复: 5

[已解决]如何实现判断字符串是否包含子字符串中所有字符

[复制链接]
发表于 2017-3-22 22:22:05 | 显示全部楼层 |阅读模式

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

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

x
问题:假设有一个字符串a,还有另外一个字符串b,而且字符串b里的字符相对少一些。从算法上讲,什么方法能最快的查出所有小字符串里的字符在大字符串里都有?
比如,如果是下面两个字符串:
String a: 12345abcdABCE
String b: 234bcABE
答案是true,所有在string b里的字母string a也都有。
  
如果是下面两个字符串:  
String a: 12345abcdABCE
String b: 234bcABEF
答案是false,因为第二个字符串里的F字符不在第一个字符串里。
最佳答案
2017-3-23 08:49:27
如果对顺序没要求可以用集合的方法。
  1. >>> str1 = '12345abcdABCE'
  2. >>> str2 = '234bcABE'
  3. >>> set1 = set(str1)
  4. >>> set2 = set(str2)
  5. >>> set2 <= set1
  6. True
  7. >>> str3 = '234bcABEF'
  8. >>> set3 = set(str3)
  9. >>> set3 <= set1
  10. False
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-3-23 00:43:22 | 显示全部楼层
对顺序有要求,则需要用正则式
对顺序没要求,当成列表做循环判断
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-23 08:39:59 | 显示全部楼层
看你怎么要求了  如果仅仅是自字符串不能变动  那么find()或者index()你可以拥有。
如果仅仅是所有字符包含在里面 那么用for循环尝试一下  Python中大小写表达的意思不一样 a和A则是两种字符
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-23 08:49:27 | 显示全部楼层    本楼为最佳答案   
如果对顺序没要求可以用集合的方法。
  1. >>> str1 = '12345abcdABCE'
  2. >>> str2 = '234bcABE'
  3. >>> set1 = set(str1)
  4. >>> set2 = set(str2)
  5. >>> set2 <= set1
  6. True
  7. >>> str3 = '234bcABEF'
  8. >>> set3 = set(str3)
  9. >>> set3 <= set1
  10. False
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-23 09:24:41 | 显示全部楼层
冬雪雪冬 发表于 2017-3-23 08:49
如果对顺序没要求可以用集合的方法。

这个不错
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-23 11:42:42 | 显示全部楼层
kmp算法
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-26 08:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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