首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从源字符串中查找多个索引

从源字符串中查找多个索引的问题,可以使用Python的多种方法来解决。以下是一个使用列表推导式和enumerate()函数的示例:

代码语言:python
代码运行次数:0
复制
source_string = "这是一个示例字符串"
target_chars = "示例"

# 使用列表推导式和enumerate()函数找到目标字符在源字符串中的所有索引
indexes = [i for i, c in enumerate(source_string) if c in target_chars]

print(indexes)

在这个示例中,我们将源字符串和目标字符设置为变量,然后使用列表推导式和enumerate()函数来找到目标字符在源字符串中的所有索引。最后,我们打印出这些索引。

这种方法适用于任何Python字符串,并且可以轻松地扩展以处理更复杂的字符串和字符组合。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

go已知列表查找字符串

01 May 2016 go已知列表查找字符串 最近在开发遇到一个需求,需要查找某个给定的字符串是否属于有效字符串。...例如以下字符串都是有效字符串: "key1" "key2" "key3" "key4" "key5" "key6" 若查找字符串是key1,存在key1,所以key1是有效字符串,若查找字符串是key0...via sort lib") } else { fmt.Println("not found via sort lib") } 方式四:使用switch 使用switch语句的特性,遍历所有字符串查找...bug,唯一的方法就是不写代码; 方式三通过使用go标准库sort,将切片先排序后,使用二分法查找目标字符串,算法复杂读相对方式二和方式四较好,为O(logN),N为切片长度,可读性较好,比方式二更优,...若查找字符串是key1,则时间复杂度O(1),但是若查找字符串是最后一个字符串时,时间复杂度和方式二一样,都是O(N),N表示字符串个数,但是该方式没有没有使用任何数据结构,如果对内存开销要求高,可以推荐使用

2.8K70
  • 字符串查找子串_cstring查找字符串

    我们在字符串 A 查找字符串 B,则 A 就是主串,B 就是模式串。我们把主串的长度记为 n,模式串长度记为 m。由于是在主串查找模式串,因此,主串的长度肯定比模式串长,n>m。...如果发现一个不等的字符,则重新回到前面的步骤查找 s 是否有字符与 t 的第一个字符相等。 如下图所示,s 的第1 个字符和 t 的第 1 个字符相等,则开始匹配后续。...字符串匹配算法的案例 最后我们给出一道面试中常见的高频题目,这也是对字符串匹配算法进行拓展,从而衍生出的问题,即查找出两个字符串的最大公共字串。...首先,你需要对于字符串 a 和 b 找到第一个共同出现的字符,这跟前面讲到的匹配算法在主串查找第一个模式串字符一样。...这样 a 和 b 每个互相匹配的字串都会被访问一遍。全局还要维护一个最长子串及其长度的变量,就可以完成了。 代码结构来看,第一步需要两层的循环去查找共同出现的字符,这就是 O(nm)。

    3K30

    【译】使用RxJava多个数据获取数据

    原文作者: Daniel Lew 译文出自: 小鄧子的简书 译者: 小鄧子 校对者: hi大头鬼hi 状态: 完成 译者注:为了方便因Lambda(译文)还不够了解的同学进行阅读,本篇译文替换了原作全部...concat()操作符持有多个Observable对象,并将它们按顺序串联成队列。 first()操作符只串联队列取出并发送第一个事件。...因此,如果使用concat().first(),无论多少个数据,只有第一个事件会被检索出并发送。...我的解决方案是,让每个数据在发送完事件后,都保存或者缓存数据。...因此,只要有一个数据的数据过期,就继续检索下一个数据,直到找到最新数据为止。

    2.5K20

    字符串匹配:字符串查找某子串

    需求 我们在平时的软件开发,尤其是嵌入式开发,字符串匹配是非常重要的一个算法。而目前常用的字符串匹配算法有很多,下面就来介绍几个。...具体算法 常规方法 对于字符串存放在字符数组的定长顺序存储结构,可以利用计数指针指示主串和模式串当前正在比较的字符位置。算法的基本思路是:主串的第i个字符起和模式串的第一个字符比较。...知道模式串被比较完成,代表主串存在模式串。...next 数组各值的含义:代表当前字符之前的字符串,有多大长度的相同前缀后缀。例如如果next [j] = k,代表j 之前的字符串中有最大长度为k 的相同前缀后缀。...这就意味着在某个字符失配时,该字符对应的next 值会告诉你下一步匹配,模式串应该跳到哪个位置(跳到next [j] 的位置)。

    1.4K30

    查找某个元素在数组对应的索引

    用户输入一个数据,查找该数据在数组索引,并在控制台输出找到的索引值,如果没有查找到,则输出 -1。 2 方法 首先定义一个数组,在键盘录入要查找的数据,用一个变量接收。...遍历数组获取数组的每一个元素。然后将键盘输入的数据和数组的每一个元素进行比较,如果值相同就把该值对应的索引赋值给索引变量,并结束循环。最后输8出索引变量。...; }else{ System.out.println("您输入的数字" + a + "在数组索引是:" + dataIndex); } }...if(a == arr[i]){ return i; } } return -1; } } 3 结语 针对查找某个元素再数组对应的索引这个问题...本文的方法缺点就是比较费时效率不高,还可以在学习了解之后通过二分法的方法来查找

    3.1K10

    JavaScript算法题:查找数字在数组索引

    我们必须对数字数组进行升序排序,并找出给定数字在该数组的位置。 算法说明 将值(第二个参数)插入到数组(第一个参数),并返回其在排序后的数组的最低索引。返回的值应该是一个数字。...请注意,在最后一个测试用例存在边界问题,其中输入数组是一个空数组。 数据结构:由于我们最终将会返回索引,因此应该坚持使用数组。...返回 num 的索引。...这个解决方案需要考虑两个边界情况: 如果输入数组为空,则我们需要返回 0,因为 num 将是该数组的唯一元素,所以它在索引为 0 的位置。...数据结构:由于我们最终将会返回索引,因此应该坚持使用数组。 让我们看看.findIndex() 并了解它将如何帮助解决这一挑战: .findIndex() 返回数组第一个满足条件的元素索引

    2K20

    linux 用 grep 查找单个或多个字符串(关键字)

    转载自 https://blog.csdn.net/qq_21840201/article/details/80344844 1、单个字符串进行查找: 1、查找当前目录文件名字符串:    grep... 字符串  文件名 2、查找某个文件字符串,并输出行号:grep -n 字符串 文件名 3、查找当前目录(包含子目录)的字符串:grep -r 字符串 * 4、查找当前目录(包含子目录)的字符串,并输出行号...:grep -rn 字符串 * * :通配符,表示当前目录所有文件,也可以按照某种模式进行匹配,例如:     grep 字符串 *.txt   匹配所有文件后缀名为txt的字符串 -r :递归查找 -...n :显示行号 -R :查找所有文件包含子目录 -i :忽略大小写 2、同时满足多个字符串查找: grep 字符串1 文件名| grep 字符串2|grep 字符串3|grep ... 3、满足多个关键字之一...grep -E "字符串1|字符串2|字符串3|"  文件名   或者 egrep  "字符串1|字符串2|字符串3|"  文件名

    16.1K10

    字符串查找----Boyer-Moore算法(右向左匹配)

    Boyer-Moore算法是一种右向左扫描模式字符串并将它与文本匹配的算法。 举例说明Boyer-Moore算法: 有文本FINDINAHAYSTACKNEEDLE和模式字符串NEEDLE....因为是右向左扫描,所以会先比较模式中最后一位E和文本中下标为5的N。不匹配,因为模式字符串也出现了N,则右移模式字符串使得模式中最右边的N(这里是位置0的N)与文本的相应N对齐。...用一个索引i在文本左向右移动,用索引j在模式字符串右向左移动。...内循环检查检查正文和模式字符串在位置i是否相等,如果M-1到0的所有j,txt.charAt(i+j)都和pat.charAt(j)相等,就是找到了匹配。...否则匹配失败,失败有三种情况: 如果造成失败的字符不包含在模式字符串,则将模式字符串向右移动j+1个位置; 如果造成失败的字符包含在模式字符串,根据right[]数组右移模式字符串; 如果这种方法无法增大

    1.2K00
    领券