输入一个字符串,计算字符串中子串出现的次数
2017-08-04 15:13
399 查看
#include <stdio.h>
int mystrlen(const char *str)
{
int length = 0;
while (*str++)
{
length++;
}
return length;
}
char* mystrstr(const char *str, const char *sub) //寻找字串,找到则返回该地址
{
int n = 0;
if (sub != NULL)
{
while (*str)
{
for (n = 0; (*(str + n) == *(sub + n)); n++)
{
if (*(sub + n + 1) == '\0')
{
return (char *)str;
}
}
str++;
}
return NULL;
}
else
{
return (char *)str;
}
}
int Substring(char *str, const char *sub)
{
char *p = str;
int count = 0;
int sublen = mystrlen(sub);
p = mystrstr(p, sub); //在主串中寻找字串
while (p != NULL)
{
count++; //找到就计数器加1,让主串指针指向该字串之后一位继续寻找
p += sublen;
p = mystrstr(p, sub);
}
return count;
}
int main()
{
char str[100] = {0};
char sub[100] = {0};
int count = 0;
printf ("Please input a main string : \n"); //主串输入
scanf ("%s", str);
printf ("Please input a sub string : \n"); //字串输入
scanf ("%s", sub);
count = Substring(str, sub);
printf ("count = %d\n", count); //打印结果
return 0;
}
int mystrlen(const char *str)
{
int length = 0;
while (*str++)
{
length++;
}
return length;
}
char* mystrstr(const char *str, const char *sub) //寻找字串,找到则返回该地址
{
int n = 0;
if (sub != NULL)
{
while (*str)
{
for (n = 0; (*(str + n) == *(sub + n)); n++)
{
if (*(sub + n + 1) == '\0')
{
return (char *)str;
}
}
str++;
}
return NULL;
}
else
{
return (char *)str;
}
}
int Substring(char *str, const char *sub)
{
char *p = str;
int count = 0;
int sublen = mystrlen(sub);
p = mystrstr(p, sub); //在主串中寻找字串
while (p != NULL)
{
count++; //找到就计数器加1,让主串指针指向该字串之后一位继续寻找
p += sublen;
p = mystrstr(p, sub);
}
return count;
}
int main()
{
char str[100] = {0};
char sub[100] = {0};
int count = 0;
printf ("Please input a main string : \n"); //主串输入
scanf ("%s", str);
printf ("Please input a sub string : \n"); //字串输入
scanf ("%s", sub);
count = Substring(str, sub);
printf ("count = %d\n", count); //打印结果
return 0;
}
相关文章推荐
- 输入一个字符串,计算字符串中子串出现的次数
- 4.3输入一个字符串,计算字符串中字串中子串出现的次数
- 输入一个字符串,计算字符串中子串出现的次数
- 输入一个字符串,计算字符串中子串出现的次数
- 输入一个字符串,计算该字符串中子串出现的次数
- 输入一个字符串,计算字符串中子串出现的次数
- 输入一个字符串,计算字符串中子串出现的次数
- 自己编写的一个求字符串中子串出现次数计算小程序字串长度为2
- 通过键盘输入一个字符串,判断字符串中出现最多的字符并输出该字符和输出出现次数
- 用es6的Array.reduce()方法计算一个字符串中每个字符出现的次数
- 判断一个字符串中子串出现的次数.
- [Java练习]输入一个字符串,输出其中某个小写字母出现的次数
- 统计一个长度为2的子字符串在另一个字符串中出现的次数.例如:假定输入的字符串为“asd asasdfg asd as zx67 asd mklo”,子字符串为“as”,函数返回值为6。
- 利用C语言实现:输入两个字符串,统计一个字符串在另一个字符串中出现的次数 。
- 计算字符串中子串出现的次数
- 编写一个程序统计输入字符串中: 各个数字、空白字符、以及其他所有字符出现的次数
- 手动输入一个字符串,仅限小写字母,统计并输出每个字符在字符串中出现的次数,并输出。
- 计算某字符串在另外一个字符串中出现的次数
- java 计算字符串中子串出现的次数
- 计算一个字符串在另一字符串中出现的次数函数