|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为“You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.”,子字符串为“im”,函数执行后打印“子字母串在目标字符串中共出现 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)
下面是我的
def findstr(name1,name2):
if name2 not in name1:
print('目标中并没有')
else:
c = name1.count(name2)
return print('子字符串在目标字符串中共出现',c,'次')
name1 = input('输入字符串一:')
name2 = input('输入要查找的字符串:')
findstr(name1,name2)
我这样的代码是不是属于投机取巧,在实际作用上 我的代码跟小甲鱼老师的代码有什么区别呢。
确实,实际作用上你的代码会快(用了内置的count),
但是小甲鱼老师的本意是要锻炼你的思维,而不是用内置的方法
|
|