首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
编写一个函数find Str(),该函数统计一个长度为2的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为“as”,函数返回值是6。 函数ReadWrite()
编写一个函数find Str(),该函数统计一个长度为2的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为“as”,函数返回值是6。 函数ReadWrite()
admin
2009-02-15
99
问题
编写一个函数find Str(),该函数统计一个长度为2的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为“as”,函数返回值是6。
函数ReadWrite()的功能是实现从文件in40.dat中读取两个字符串,并调用函数findStr(),最后把结果输出到文件out40.dat中。
注意:部分源程序已给出。
请勿改动主函数main()和其他函数中的任何内容,仅在函数findStr()的花括号中填入你所编写的若干语句。
试题程序:
#include<stdio.h>
#include<string.h>
#include<conio.h>
int findStr(char *str,char *substr)
{
}
main()
{
char str[81],substr[3];
int n;
clrscr();
printf ("输入原字符串:");
gets(str);
printf("输入子字符串:");
gets(substr);
puts(str);
puts(substr);
n=findstr(str,substr);
printf("n=%d\n",n);
ReadWrite();
}
ReadWrite()
{
char ch,str[81],substr[3];
int n, len, i=0;
FILE *rf,*wf;
rf=fopen ("in40.dat","r");
wf=fopen ("out40.dar","w");
while (i<5)
{
fgets(str,80,rf);
fgets(substr,10,rf);
len=strlen(substr)-1;
ch=substr[len];
if(ch==’\n’||ch==0x1a)
substr[len]=0;
n=findStr(str, substr);
fprintf(wf,"%d\n",n);
i++;
}
fclose(rf);
fclose(wf);
}
选项
答案
int findStr(char*str,char*substr) { int n; char *p,*r; n=0; while(*str) { p=str; /*指针p指向字符串首地址*/ r=substr; /*指针r指向子字符串首地址*/ while(*r) if(*r==*p) /*如果子字符串的第一个字符等于字符串中的该字符,则继续比较下一个字符*/ { r++; p++; } else break; /*否则退出循环*/ if(*r==’\0’) /*如果子字符串在字符串中出现了一次*/ n++; /*则n加1,进行统计*/ str++; /*指向字符串中的下一个字符*/ } return n; /*返回n*/ }
解析
本题考查的知识点如下:
(1)指针的相关操作。
(2)强行退出——break的使用。
指针是C语言中的一个难点。在这里,我们要使用指针实现对数组的访问继而进行字符的比较。使用数组存放字符串时,存放的字符个数要比数组的容量小1,因为数组最后一个位置存放的是空格或者结束标志位。我们可利用这一点来判断一个字符串是否已经结束。在循环结构中常常要出现强行退出的情况,这里要使用到break语句强行退出一层循环。当字符串中的某个字符与子字符串的第一个字符不同时,则将字符串中的下一个字符与子字符串中的第一个字符比较,而不是与子字符串中的第二个字符比较。
转载请注明原文地址:https://kaotiyun.com/show/UtfZ777K
本试题收录于:
三级信息管理技术题库NCRE全国计算机三级分类
0
三级信息管理技术
NCRE全国计算机三级
相关试题推荐
下列选项中,哪一项可以用于数字签名()。
在FTP安装前的准备工作中,由于Winmail邮件服务器支持基于Web方式的访问管理,因此安装邮件服务器前需安装()。
通常,完整的电子邮件地址由两部分构成,第一部分为信箱名,第二部分为服务器的域名,中间用()隔开。
FTP服务器配置的主要参数包括:域、匿名用户、组和()。
WWW服务器结构中,浏览器与服务器之间传输信息的协议是()。
设有某一个令牌环网长度为400米,环上有28个站点,其数据传输率为4Mbps,环上信号的传播速度为200m/μs,每个站点具有1bit时延,则环上可能存在的最小时延分别是______bit。
在病毒的生存期内,病毒将与自身完全相同的副本放入其他程序或者硬盘上的某些特定分区中,这个阶段称之为______。
A、 B、 C、 D、 D标准IP地址分类利用率低,路由器工作效率低,所以人们提出了子网的概念。子网的划分利于优化网络性能,改善网络管理。IP地址是层次型结构的,它的长度是32位。子网的概念可以应用于A类、B
A、 B、 C、 D、 A增量备份只备份相对于上一次备份操作以来新创建或者更新过的数据。比完全备份更快、更小。但可靠性差。在这种备份方式下,各盘磁带间的关系就像链子一样,一环套一环,其中任何一盘磁带出现了问题
随机试题
企业以人为本,形成一流的员工队伍,为市场创造适销对路的产品,提供最佳的服务,以展现员工良好的职业道德、较高的文化素养,崇高的精神风貌所进行的长远性谋划与方略是()
下列对计算机软件认识不正确的是______。
A.急性闭角型青光眼B.弱视C.缺血性视神经病变D.开角型青光眼E.以上均不是逐渐视力下降无眼痛
格林-巴利综合征脑脊液的特点是
移动平均法应用于消极型股票投资战略。( )
公司债券只能是记名债券。()
驾驶员在正常行车途中,发现两个小孩从侧面横过马路,驾驶员刹不住车,急转方向盘,汽车朝路旁的空房撞去,致车和空房损坏严重。驾驶员的行为是()。
政策性投资也叫竞争性投资。()
下列说法中,正确的是
Wheremostlikelyarethespeakers?
最新回复
(
0
)