请高手帮忙解决一道C语言的编程题!~~急啊!~~

2025-01-20 05:52:51
推荐回答(2个)
回答1:

代码及其不规范,首先给你修改规范,然后给你编上行号,给你说
1 int findStr(char *str,char *substr)
2 {
3 int n;
4 char *p , *r;
5 n=0;
6 while ( *str )
7 {
8 p=str;
9 r=substr;
10 while(*r)
11 if(*r==*p) { r++; p++; }
12 else break;
13 if(*r=='\0')
14 n++;
15 str++;
16 }
17 return n;
18}
====================================================================
首先此题不用指针作,很麻烦,而且函数原形都要修改,要添加两个字符串长度参数,才可以不再使用指针。还是给你讲解这个程序的流程吧。
6 while ( *str )
这个循环是从源串第一个字节开始,一直碰到'\0'结束,因为'\0'的ASCII码为0,也就是NULL。下面代码已知道Line 16都是这个循环体。
8 p=str;
9 r=substr;
取得两个字串当前指针,为作比较准备,
10 while(*r)
11 if(*r==*p) { r++; p++; }
12 else break;
这个循环的条件和Line 6差不多。其中这个循环是这样的,将连个字串的第一个字节开始比较,如果相等则比较下一个,一直到r结束还是相等的,这个字串就在str中出现过,否则到Line 12执行,跳出循环。
11 if(*r==*p) { r++; p++; } 如果这两个字节相等,则比较下一个字。
12 else break;不相等,跳出循环。
以下这两句是判断刚才循环结束的原因
13 if(*r=='\0') 如果r指针指向的字节是'\0',那么表示整个字符串都匹配了,因此就让计数器n自加1,然后从源串下一个字节开始再次匹配。
14 n++;
15 str++;
知道str指向字符串结束,程序结束了。
====================================================================
还有楼主连指针都看不懂,那就危险了。

回答2:

请给出完整程序