鱼C论坛

 找回密码
 立即注册
查看: 1805|回复: 4

[已解决]子字符串在母字符串中出现的次数

[复制链接]
发表于 2021-1-17 21:02:47 | 显示全部楼层 |阅读模式

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

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

x
这个程序,有两处看不懂555:
1.        for each1 in range(length-1):      
            if desStr[each1] == subStr[0]:
                if desStr[each1+1] == subStr[1]:
                    count += 1

这里for in range 看不懂,求大佬解析一下

2.print('子字符串在目标字符串中共出现 %d 次' % count)
这句也没看懂

3.另外我的课后作业动动手都是自己做不出来的,其他人都可以做出来吗,我哭泣了

def findStr(desStr, subStr):
    count = 0
    length = len(desStr)
    if subStr not in desStr:
        print('在目标字符串中未找到字符串!')
    else:
        for each1 in range(length-1):      
            if desStr[each1] == subStr[0]:
                if desStr[each1+1] == subStr[1]:
                    count += 1
                    
        print('子字符串在目标字符串中共出现 %d 次' % count)

desStr = input('请输入目标字符串:')
subStr = input('请输入子字符串(两个字符):')
findStr(desStr, subStr)
最佳答案
2021-1-17 21:06:25
def findStr(desStr, subStr):     
    count = 0
    length = len(desStr)
    if subStr not in desStr:
        print('在目标字符串中未找到字符串!')
    else: #这里的条件是字串在目标字符串里
        for each1 in range(length-1): #length为目标字符串的长度,减一刚好是目标串的索引范围
            #而for...in range(n)的语法中,...只是一个循环变量名字而已,叫i,j,k,each,什么都可以,它的取值是range函数规定的,0到n-1;
            # each1就是下面要用到的字符串索引值     
            if desStr[each1] == subStr[0]:  #这里只不过是比较目标串的各个字符有没有和字串第一个字符相同的,如果相同,进入下一层判断
                if desStr[each1+1] == subStr[1]: #与字串第一个字符匹配后,移到后一位字符进行判断,索引值加一就是后移一位,没什么难理解的
                    count += 1 #前两个条件都满足了,计数出现次数加一
                    
        print('子字符串在目标字符串中共出现 %d 次' % count)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-1-17 21:06:25 | 显示全部楼层    本楼为最佳答案   
def findStr(desStr, subStr):     
    count = 0
    length = len(desStr)
    if subStr not in desStr:
        print('在目标字符串中未找到字符串!')
    else: #这里的条件是字串在目标字符串里
        for each1 in range(length-1): #length为目标字符串的长度,减一刚好是目标串的索引范围
            #而for...in range(n)的语法中,...只是一个循环变量名字而已,叫i,j,k,each,什么都可以,它的取值是range函数规定的,0到n-1;
            # each1就是下面要用到的字符串索引值     
            if desStr[each1] == subStr[0]:  #这里只不过是比较目标串的各个字符有没有和字串第一个字符相同的,如果相同,进入下一层判断
                if desStr[each1+1] == subStr[1]: #与字串第一个字符匹配后,移到后一位字符进行判断,索引值加一就是后移一位,没什么难理解的
                    count += 1 #前两个条件都满足了,计数出现次数加一
                    
        print('子字符串在目标字符串中共出现 %d 次' % count)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-17 21:11:28 | 显示全部楼层

print('子字符串在目标字符串中共出现 %d 次' % count)

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

使用道具 举报

发表于 2021-1-17 21:13:37 | 显示全部楼层
至于
print('子字符串在目标字符串中共出现 %d 次' % count)
这是print函数的一种输出形式
就是用%后面的变量来代替%前面格式串里的%d的位置而已
以后会经常用到
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-17 21:15:51 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 21:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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