| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
x
 
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) 
这一段的else后面,为什么是for each1,一般不是用的for each in吗,还有后面的Length-1是什么意思啊,包括后面的each1,我知道他想表达的是指字符串里面的每一个字母,each1+1表示上一个字母的下一个,但是这种表达,感觉不能理解。
 
因为字符串 length 值为你的原字符串总长度,而 for 循环中 通过两个 if 判断是否等于需要替换的字符 
 
desStr[each1] 是指此时 for 循环索引到的第一个字符,desStr[each1+1] 指第二个 
 
length - 1 就是为了防止 for 循环到末尾字符时,each1+1 大于 length 即超出字符串总长度二导致报错 
 
 
 
 
 |   
 
 
 
 |