首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
编写一个函数findStr(),该函数统计一个长度为2的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为“as”,函数返回值是6。 函数ReadWrite()的
编写一个函数findStr(),该函数统计一个长度为2的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为“as”,函数返回值是6。 函数ReadWrite()的
admin
2009-02-24
63
问题
编写一个函数findStr(),该函数统计一个长度为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.dat", "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/kRYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
Oracle针对Internet/Intranet的产品是
在文件系统中,文件的逻辑结构可分为两类,它们是【】文件和记录式文件。
A、 B、 C、 D、 BPowerDesigner中ProcessAnalyst用于数据分析和数据发现,使用户能够描述复杂的处理模型以反映他们的数据库模型,产生数据字典,绘制数据流程图等。
通常一台计算机系统的存储介质包括Cache、内存、磁带和硬盘,其中访问速度最慢的是()。
设有如下关系:学生(学号,姓名,性别,年龄,班号)其关键字是学号,将学号为10的学生姓名改为“王华”的SQL语句是【】。
下列关于异步传输模式ATM技术的叙述中,哪一条是不正确的?
设有一个二维数组A[1…4,1…6],若数组的起始地址为200,并且数据元素以行序为主序存放在数组中,每个元素占用4个存储单元,那么元素A[3,4]的存储地址为
在下面的叙述中,属于TCP/IP协议特点的是Ⅰ.开放的协议标准,独立于特定的计算机硬件与操作系统Ⅱ.可以运行在局域网、广域网,更适用于互联网Ⅲ.整个TCP/IP设备在网络中具有惟一的Ip地址Ⅳ.可以提供多种可靠的用户
在SQLServer2008中,有两种身份验证模式,一种是混合身份验证模式,另一种是【9】身份验证模式。
最古老的一种置换密码是由JuliusCaesar发明的_______。
随机试题
电焊工防灼伤的措施有哪些?
行政机关依法定的职权对行政主体及执行公务的人员的行政责任进行追究的方式有()
分包企业签署质量合格的文件上,必须由()的注册建造师签章。
混凝土水灰比应根据施工现场的水泥、砂、石等原材料质量,由()确定。
下列影响企业风险补偿率的因素有()。
某企业只生产一种产品,采用约当产量比例法将生产费用在完工产品与在产品之间进行分配,材料在产品投产时一次投入,月初在产品直接材料成本为10万元,当月生产耗用材料的成本为50万元,当月完工产品30件,月末在产品30件,完工程度60%,本月完工产品成本中直接材料
逆回购意味着中央银行从市场收回流动性。()
“你肚里有墨水儿,脑袋瓜儿又活,看个文件什么的,只要拿眼把题目一扫,里面的内容便能猜个大概”所用的辞格是婉曲。()
下列关于IEEE802.11标准的描述中,错误的是()。
WhofirstclaimedAustraliafortheU.K.?
最新回复
(
0
)