请高手帮忙解决一道C语言的编程题!~~急啊!~~
计算机等级考试将至,今有C编程一题实在弄不懂,它的答案用的是指针解答的,望有高手可以用普通的方法帮我解答一下!!大恩不言谢!!编写一个函数findstr(),该函数统计一...
计算机等级考试将至,今有C编程一题实在弄不懂,它的答案用的是指针解答的,望有高手可以用普通的方法帮我解答一下!!大恩不言谢!!
编写一个函数findstr(),该函数统计一个长度为2的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为"as",函数返回值为6。
函数readwriteDat()的功能是实现从文件in.dat中读取两个字符穿4,并调用函数findstr(),最后把结果输出到文件out.dat中。
注意:部分源程序已给出。
请勿改动主函数main()和函数ReadWrite()的内容。
原题答案:
int findStr(char *str,char *substr)
{ int n;
char *p , *r;
n=0;
while ( *str )
{ p=str;
r=substr;
while(*r)
if(*r==*p) { r++; p++; }
else break;
if(*r=='\0')
n++;
str++; }
return n;
}
请大家务必用普通的方法帮我解答!!对于指针我实在看不懂!~~
谢谢大家!!!
我是考3级网络技术,上级就考一道C,我其实一点也不会C的,听考过的人说上机答题时最好不用指针,我也刚学了一点C,又没什么时间,所以实在不想碰指针……
听大家这么说,反正那100题就这么一套非用指针不可,我就给它背下来好了……
再次感谢各位!!! 展开
编写一个函数findstr(),该函数统计一个长度为2的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为"as",函数返回值为6。
函数readwriteDat()的功能是实现从文件in.dat中读取两个字符穿4,并调用函数findstr(),最后把结果输出到文件out.dat中。
注意:部分源程序已给出。
请勿改动主函数main()和函数ReadWrite()的内容。
原题答案:
int findStr(char *str,char *substr)
{ int n;
char *p , *r;
n=0;
while ( *str )
{ p=str;
r=substr;
while(*r)
if(*r==*p) { r++; p++; }
else break;
if(*r=='\0')
n++;
str++; }
return n;
}
请大家务必用普通的方法帮我解答!!对于指针我实在看不懂!~~
谢谢大家!!!
我是考3级网络技术,上级就考一道C,我其实一点也不会C的,听考过的人说上机答题时最好不用指针,我也刚学了一点C,又没什么时间,所以实在不想碰指针……
听大家这么说,反正那100题就这么一套非用指针不可,我就给它背下来好了……
再次感谢各位!!! 展开
2个回答
展开全部
代码及其不规范,首先给你修改规范,然后给你编上行号,给你说
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指向字符串结束,程序结束了。
====================================================================
还有楼主连指针都看不懂,那就危险了。
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指向字符串结束,程序结束了。
====================================================================
还有楼主连指针都看不懂,那就危险了。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询