统计子字符串substr在字符串str中出现的次数
时间: 2023-11-15 14:04:32 浏览: 194
可以使用字符串的find方法来实现统计子字符串在字符串中出现的次数。具体的做法是,使用循环和find方法依次查找子字符串在字符串中的位置,每次查找到一个位置就将查找的起点更新为该位置的下一个位置,直到查找不到为止。代码如下:
```python
def count_substr(str, substr):
count = 0
start = 0
while True:
pos = str.find(substr, start)
if pos == -1:
break
count += 1
start = pos + 1
return count
```
这个函数接受两个字符串参数,分别是要查找的原字符串和要统计的子字符串。函数返回子字符串在原字符串中出现的次数。例如:
```python
str = "hello world, world is beautiful"
substr = "world"
count = count_substr(str, substr)
print(count)
```
输出结果为:
```
2
```
相关问题
用c语言循环统计子字符串substr在字符串str中出现的次数
可以使用两层循环遍历字符串str,逐个匹配判断是否为子字符串substr,并在匹配成功时计数器加1。具体代码如下:
```c
#include <stdio.h>
#include <string.h>
int count_substr(const char* str, const char* substr) {
int count = 0;
int len_str = strlen(str);
int len_substr = strlen(substr);
for (int i = 0; i < len_str - len_substr + 1; i++) { // 遍历字符串str
int j;
for (j = 0; j < len_substr; j++) { // 遍历子字符串substr
if (str[i+j] != substr[j])
break;
}
if (j == len_substr) // 匹配成功
count++;
}
return count;
}
int main() {
char str[] = "hello world, hello everyone!";
char substr[] = "hello";
int count = count_substr(str, substr);
printf("'%s' appears %d times in '%s'\n", substr, count, str);
return 0;
}
```
输出:
```
'hello' appears 2 times in 'hello world, hello everyone!'
```
下列给定程序函数fun的功能是:统计子字符串substr在字符串str中出现的次数。例如,若字符串aaas lkaaas,子字符串为as,则应输出2。
函数`fun`的主要功能是通过遍历字符串`str`,查找子字符串`substr`在`str`中出现的位置,并计算子字符串出现的总次数。它通常会采用循环结构,每次搜索子字符串开始位置,如果找到匹配的部分,计数器加一,然后继续搜索直到字符串结束。这个过程可能会用到字符串处理函数如`find()`或`indexOf()`来定位子字符串。
下面是一个简单的伪代码示例:
```python
def fun(str, substr):
count = 0
start = 0
while True:
index = str.find(substr, start)
if index == -1: # 如果找不到子串,返回当前计数
return count
count += 1 # 找到子串,计数加一
start = index + 1 # 更新搜索起始位置,跳过已找到的部分
# 示例:
str = "aaas lkaaas"
substr = "as"
result = fun(str, substr)
print("子字符串", substr, "在", str, "中出现了", result, "次")
```
阅读全文