首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:除了尾部的*号之外,将字符串中其他*号全部删除。形参p己指向字符串中最后的一个字母。在编写函数时,不得使用C语言提供的字符串函数。 例如,字符串中的内容为:****A*BC*DEF*
假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:除了尾部的*号之外,将字符串中其他*号全部删除。形参p己指向字符串中最后的一个字母。在编写函数时,不得使用C语言提供的字符串函数。 例如,字符串中的内容为:****A*BC*DEF*
admin
2019-03-19
91
问题
假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:除了尾部的*号之外,将字符串中其他*号全部删除。形参p己指向字符串中最后的一个字母。在编写函数时,不得使用C语言提供的字符串函数。
例如,字符串中的内容为:****A*BC*DEF*G*******,删除后,字符串中的内容应当是:ABCDEFG*******。
注意:部分源程序在文件PROG1.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
1 #include<stdio.h>
2 void fun(char *a,char *p)
3 {
4 }
5 main()
6 { char s[81],*t;
7 void NONO();
8 printf(’’Enter a string:\n’’);gets(s);
9 t=s;
10 while(*t)t++;
11 t--;
12 while(*t==’*’)t--;
13 fun(s,t);
14 printf(’’The string after deleted:\n’’);puts(s);
15 NONO();
16 }
17 void NONO()
18 {/*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */
19 FILE *in,*out;
20 int i;char s[81],*t;
21 in=fopen(’’in.dat’’,’’r’’);
22 out=fopen(’’out.dat’’,’’w’’);
23 for(i=0;i<10;i++) {
24 fscanf(in,’’%s’’,S);
25 t=s;
26 while(*t)t++;
27 t--;
28 while(*t==’*’)t--;
29 fun(s,t);
30 fprintf(out,’’%s\n’’,s);
31 }
32 fclose(in);
33 fclose(out);}
选项
答案
1 char *q=a; 2 int j=0; 3 while(*q&&q<p){ 4 if(*q !=’*’)a[j++]=*q; 5 q++; 6 } 7 while(*p)a[j++]=*p++; 8 a[j]=’\0’;
解析
该程序功能是除了尾部的“*”号之外,将字符串中其他“*”号全部删除。其中,实现删除指定元素的功能,一般是使用循环语句,通过指针变量在字符串中前后的移动,判断其是否为要删除的元素。若是,则进行相应的操作。还要注意的是,删除字符后,要将其后的字符依次移动。
(1)首先,主函数中使指针移到字符串的最后一个字符,对字符串由串尾开始进行操作。
(2)然后,指针由尾开始向头移动,查找第一个非“*”号字符,指针t指向后一个非“*”,即从最后一个非“*”,字符开始的字符都不需要删除,将前面的其他“*”号全部删除后,将尾部的“*”字符往前移动即可。
(3)确定了字符数组的最后一个字符非“*”后,调用fun函数,在fun函数中,将原串中由起始位置的字符开始到最后一个非“*”逐个查询该字符是否是“*”字符,如果是则删除,并将后面的字符往前移动;然后将t之后的字符移动到前面,最后在字符串的后面添加“’\0’”即可。
转载请注明原文地址:https://kaotiyun.com/show/QBRp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指
下面的程序可对指定字符串中的字符串进行从大到小排序,请将程序填完整。(注:程序采用了冒泡排序算法)#include<stdio.h>#include<string.h>main(){char*str="ABCDabcd
以下程序的输出结果是()。#include<stdio.h>voidfun(intx){if(x/2>0)fun(x/2);printf("%d",x);}main(){fun(
函数pi的功能是根据以下公式近似求得的:pi*pi/6=1+1/(2*2)+1/(3*3)+…+1/(n*n)请在下面的函数中填空,完成求pi的功能。#include<math.h>doublepi(longn)
Jackson方法是一种面向______的结构化方法。
有如下程序 #include<stdio.h> main() { int a[4][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16)); int i,s=0; for(i=0;i<4;i++)s+=a[i
下面程序的功能是两个整数进行交换,请填空。sub(int*x,int*y){【】z=*x;*x=*y;*y=z;return;}main(){intm,n,*t1,*t2;
下面的程序实现的是指针p所指向的地址的n个数中,求出最大的和最小的数据,请填空。fun(int*p,intn){int*q;intmax,min;max=min=*p;for(q=p;【】
下面函数调用语句含有实参的个数为func((exp1,exp2)(exp3,exp4,exp5));
随机试题
中国证监会于2009年7月受理了甲股份有限公司(本题下称“甲公司”)申请在主板首次公开发行股票并上市的申报材料,该申报材料披露了以下相关信息:(1)甲公司(非金融类企业)本次发行前的股本总额为人民币4000万元(每股面值人民币1元),本次拟发行800
设函数y(x)是微分方程求y(x);
重度有机磷中毒的主要症状是
公民、法人和其他组织对行政机关和非行政机关共同署名作出的处理决定不服而提起诉讼时,非行政机关()。
在社会生活噪声排放源边界处无法进行噪声测量或测量的结果不能如实反映其对噪声敏感建筑物的影响程度的情况下,噪声测量应在可能受影响的敏感建筑物窗外()m处进行。
在确定土料压实参数的碾压试验中,一般以单位压实遍数的压实厚度()者为最经济合理。
在紧急排险中需拆除的建筑物、毁坏的其他设施的所有者,必须无条件地服从()的指挥,履行拆除的义务。
设直线y=kx与曲线y=所围平面图形为D,它们与直线x=1围成平面图形为D.求k,使得D1与D2分别绕x轴旋转一周成旋转体体积V1与V2之和最小,并求最小值:
你可以怎么计划呢这项破坏
A=BOOKREVIEW1B=BOOKREVIEW2C=BOOKREVIEW3D=BOOKREVIEW4Whichbookreview(s)contain(s)thefollowinginformation?
最新回复
(
0
)