版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
全国计算机二级C语言上机题题库(超值100题)
1:第1题m个人的成绩寄存在score数组中,请编写函数fun,它的功能是:将
低于平均分H勺人作为函数值返回,将低于平均分的分数放在below所指定H勺函
数中。
答案:
intfun(intscore[]zintmjntbelow[])
(
inti,k=0zaver=0;
for(i=0;i<m;i++)
aver+=score[i];
aver/=m;
for(i=0;i<m;i++)
if(score[i]<aver)
{
below[k]=score[i];
k++;
}
returnk;
}
2:第2题请编写函数fun,它的功能是:求出1到100之内能北7或者11整除,
但不能同步北7和11整除H勺所有证书,并将他们放在a所指的数组中,通过n
返回这些数H勺个数。
答案:
voidfun(int*a,int*n)
intij=0;
for(i=2;i<1000;i++)
if((i%7==0||i%U==0j&&i%77!=0)
a[j++]=i;
*n=j;
}
3:第3题请编写函数voidfun(intx,intpp口,int*n),它的功能是:求出能整除x
且不是偶数的各整数,并按从小到大的次序放在pp所指的数组中,这些除数的
个数通过形参n返PU
答案:
voidfun(intxzintpp[]zint*n)
(
inti=l,j=O;k=O,*t=pp;
for(i=0;i<=x;i++)
if(i%2!=0)
(
«]=1;
j++;
}
for(i=0;i<j;i++)
if(x%t[i]==O)
pp[k]=t[i];
k++;
}
*n=k;
}
4:第4题请编写•种函数voidfun(char*ttzintpp[第记录在tt字符中“a”到
"z"26各字母各自出现的次数,并依次放在pp所指的数组中。
答案:
voidfun(char*tt,intpp[])
{
inti;
for(i=0;i<26;i++)
PP[i]=0;
while(*tt)
{
switch(*tt)
(
case'az:pp[0]++;break;
case'b':pp[l]++;break;
case'c':pp[2]++;break;
case'd':pp[3]++;break;
case'e':pp[4]++;break;
casef:pp[5]++;break;
case'g':pp[6]++;break;
case'h':pp[7]++;break;
case?:pp[8]++;break;
casey:pp[9]++;break;
case'k':pp[10]++;break;
case'K:pp[ll]++;break;
case'm':pp[12]++;break;
case'n7:pp[12]++;break;
case'o':pp[14]++;break;
case'p':pp[15]++;break;
case'q':pp[16]++;break;
case'「':pp[17]++;break;
case's':pp[18]++;break;
case't:pp[19]++;break;
case'u':pp[20]++;break;
caseV:pp[21]++;break;
case'w':pp[22]++;break;
case'x':pp[23]++;break;
casey:pp[24]++;break;
case'z':pp[25]++;break;
}
tt++;
)
)
5:第5题请编写一种函数voidfun(intm,intk,intxx口),该函数口勺功能是:将不
小于整数m且紧靠mH勺k各素数存入xx所指的数组中。
答案:
voidfun(intm,intk,intxx[])
(
intg=O,IJ,flag=l;
for(i=m+l;i<m*m;i++)
{
forQ=0;j<I;j++)
{
if(i%j!=O)
flag=l;
else
{
flag=O;
break;
}
}
if(flag==l&&j>=i)
{
if(k>=0)
xx[g++]=i;
)
else
break;
}
}
}
6:第6题请编写一种函数voidfun(chara口,char口,intn),其功能是:删除以各
字符串中指定下标的字符,其中,a指向原字符串,删除后的I字符串寄存在b所
指的J数组中,n中寄存指定的下标。
答案:
voidfun(chara[],charb口,intn)
{
intIzj=0;
for(i=0;iVLEN;i++)
if(i!=n)
{
bO]=a[i];
j++;
}
b[j]='\O';
}
7:第7题请编写一种函数毗何十毗*与丽",毗*1<),用来求除数组口勺最大元素
在数组中H勺下标并寄存在k所指的储存单元中。
答案:
voidfun(int*s,intt,int*k)
{
intI,max;
max=s[0];
for(i=0;i<t;i++)
if(s[i]>max)
(
max=s[i];
*k=I;
}
)
8:第8题编写函数fun,功能是:根据如下攻势计算s,计算成果作为函数值返
回;n通过形参传入。S=l+l/(l+2)+l/(l+2+3)+…….+1/(1+2+3+4+……+n)
答案:
floatfun(intn)
{
inti;
floats=1.0,t=1.0;
for(i=2;i<=n;i++)
t=t+i;
s=s+l/t;
)
returns;
}
9:第9题编写一种函数fun,它的功能是:根据如下公式求pH勺值,成果由函
数值带回。M与n为两个正整数,且规定m>n。p=m!/n!(m-n)!
答案:
floatfun(intm,intn)
(
floatpzt=1.0;
intI;
for(i=l;i<=m;i++)
P=t;
for(t=1.0zi=l;i<=n;i++)
p=p/t;
for(t=1.0,i=l;i<=m-n;i++)
p=p/t;
returnp;
)
10:第10题编写函数fun,它H勺功能是:运用如下H勺简朴迭代措施求方程
cos(x)-x=0的一种实根。
迭代环节如下:⑴取xl初值为0.0;(2)x0=xl,把xl时值赋各x0;
(3)xl=cos(x0),求出一才中新H勺xl;
(4)若xO-xl的绝对值不不小于0,000001,则执行环节(5),否则执行环节(2);
(5)所求xl就是方程cos(x)-x=0H勺一种实根,作为函数值返回。
程序将输出root=0.739085。
答案:
floatfun()
(
floatxl=0.0zx0;
do
(
x0=xl;
xl=cos(x0);
)
while(fabs(x0-xl)>le-6);
returnxl;
}
11:第11题下列程序定义了nxn/j二维数组,并在主函数中自动赋值。请编
写函数fun(inta[][n]),该函数的功能是:使数组左下半三角元素中H勺值所有置
成0。
答案:
intfun(inta[][N])
{
intI,j;
for(i=0;i<N;i++)
forO=0;j<=I;j++)
a口皿=0;
}
12:第12题下列程序定义了nxn/j二维数组,并在主函数中赋值。请编写函
数fun,函数的功能使求出数组周围元素H勺平均值并作为函数值返回给主函数中
的s。
答案:
doublefun(intw[][N])
(
intIzj,k=O;
doubles=0.0;
for(j=0;j<N;j++)
{
s+=w[0][j];
k++;
}
for(j=0;j<N;j++)
s+=w[N-l][j];
k++;
}
for(i=l;i<=N-2;i++)
(
s+=w[i][O];
k++;
}
for(i=l;i<=N-2;i++)
{
s+=w[i][N-l];
k++;
)
returns/=k;
}
13:第13题请编写一种函数voidfun(inttt[m][n],intpp[n]),tt指向一种m行n
列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维
数组中。二维数组中H勺数已在主函数中赋予。
答案:
voidfun(inttt[M][N],intpp[N])
intIjzmin;
for(j=0;j<N;j++)
min=tt[O][j];
for(i=0;i<M;i++)
{
if
min=tt[i][j];
}
pp[j]=min;
}
)
14:第14题请别写函数fun,函数的功能使求出二维数组周围元素之和,作为函
数值返回。二维数组中的值在主函数中赋予。
答案:
intfun(inta[M][N])
{
intI,j,s=O;
for(j=0;j<N;j++)
{
s+=a[O]U];
s+=a[M-l][j];
}
for(i=l;i<=M-2;i++)
s+=a[i][O];
s+=a[i][N-l];
}
returns;
}
15:第15题请编写一种函数unsignedfun(unsignedw),w使一种不小于10H勺
无符号整数,若w使n(n22)位的J整数,则函数求出w后n—l位的数作为函数
值返回。
答案:
unsignedfun(unsignedw)
{
unsignedt,s=0zsl=l/p=0;
t=w;
while(t>10)
{
if(t/10)
p=t%10;
s=s+p*sl;
sl=sl*10;
t=t/10;
)
returns;
}
16:第16题请编写一种函数floatfun(doubleh),函数的功能使对变量h中口勺值
保留2位小树,并对第三位进行四舍五入(规定h中的值位正数)。
答案:
floatfun(floath)
{
longt;
floats;
h=h*1000;
t=(h+5)/10;
s=(float)t/100.0;
returns;
}
17:第17题请编写一种函数fun(cha「*s),该函数H勺功能使把字符串中的内容
拟置。
答案:
voidfun(char*s)
{
charch;
int
i=0;
m=n=strlen(s)-l;
while(i<(n+l)/2)
{
ch=s[i];
s[i]=s[m];
s[m]=ch;
i++;
m-;
}
)
18:第18题编写程序,实现矩阵(3行3歹U)的转置(即行列互换)。
答案:
voidfun(intarray[3][3])
(
intI,j,temp;
for(i=0;i<3;i++)
for0=O;j<I,j++)
{
temp=array[i][j];
array[i]U]=arrayD][i];
array[j][i]=temp;
)
}
19:第19题编写函数fun,该函数口勺功能是:从字符中删除指定的字符,同一字
母啊大、小写按不一样字符处理。
答案:
voidfun(chars[]zintc)
{
inti=0;
char*p;
P=s;
while(*p)
{
if(*p!=c)
(
s[i]=*p;
i++;
}
p++;
}
s[i]='\0,;
}
20:第20题编写函数intfun(intlim,intda[max]),该函数的功能是求出不不小
于或等于limH勺所有素数并放在aa数组中,该函数返回所求的素数的个数。
答案:
intfun(intlimzintaa[MAX])
{
intk=0JJ;
for(i=lim;i>l;i-)
(
for(j=2;j<i;j++)
jf(i%j==0)
break;
else
continue;
if(j>=i)
(
aa[k]=i;
k++;
)
}
returnk++;
}
21:第21题请编写函数fun,对长度位7个字符F、J字符串,除首尾字符外,将其
他5个字符按ascii码降序排列。
答案:
voidfun(char*szintnum)
{
chart;
intIJ;
for(i=l;i<num-2;i++)
for(j=i+l;j<num-l;j++)
if(s[i]<sU])
(
t=s[i];
s[i]=sU];
s[j]=t;
)
}
22:第22题n名学生口勺成绩已在主函数中放入一种带头节点日勺链表构造中,h
指向链表H勺头节点。请编写函数fun,它的功能是:找巴学牛田勺最高分,由函数
值返风
答案:
doublefun(STREC*h)
doublemax;
STREC*q=h;
max=h->s;
do
(
if(q->s>max)
max=q->s;
q=q->next;
}
while(q!=0);
returnmax;
}
23:第23题请编写函数fun,该函数H勺功能是:判断字符串与否为回文?若是则
函数返回1,主函数中输出yes,否则返回0,主函数中输出no。回文是指顺读和
倒读都是同样H勺字符串。
答案:
intfun(char*str)
{
intIzn=O;fg=l;
char*p=str;
while(*p)
(
n++;
P++;
)
for(i=0;i<n/2;i++)
if(str[i]==str[n-l-i]);
else
{
fg=O;
break;
}
returnfg;
}
24:第24题请编写一种函数fun,它的功能是:将一种字符串转换为一种整数
(不得调用c语言提供H勺将字符串转换为整数的函数)。
答案:
longfun(char*p)
(
longs=0,t;
inti=Ozjzn=strlen(p),k,sl;
jf(p[0]=='-o
i++;
forQ=I;j<=n-l;j++)
(
t=P时U;
sl=10;
for(k=j;k<n-l;k++)
t*=sl;
s+=t;
)
return-s;
else
returns;
}
25:第25题请编写一种函数fun,它口勺功能是:比较两个字符串的长度,(不得
调用c语言提供H勺求字符串长度的函数),函数返回较长的字符串。若两个字符
串长度相似,则返回第一种字符串。
答案:
char*fun(char*szchar*t)
(
char*p/*tl=t,*sl=s;
intn=0;m=0;
while(*sl)
(
n++;
sl++;
}
while(*tl)
m++;
tl++;
)
if(n>=m)
P=s;
else
P=t;
returnp;
}
第26题请编写一种函数fun,它口勺功能是:根据如下公式求x的值(规定满足精
度0.0005,即某项不不小于0.0005时停止迭代):
X/2=1+1/3+1X2/3X5+1X2X3/3X5X7+1X2X3X4/3X5X7X9+-+1X2
x3x-xn/3x5x7x(2n+l)
程序运行后,假如输入精度0.0005,则程序输出为3.14…。
答案:
doublefun(doubleeps)
(
doubles;
floatn,t,pi;
t=l;pi=0;n=1.0;s=1.0;
while((fabs(s))>=eps)
(
Pi+=s;
t=n/(2*n+l);
s*=t;
n++;
}
pi=pi*2;
returnpi;
}
27:第27题请编写一种函数fun,它日勺功能是:求除1到m之内(含m)能北7
或11整除的所有整数放在数组a中,通过n返回这些数的I个数。
答案:
voidfun(intm,int*a,int*n)
(
intIj=0;*n=0;
for(i=l;i<=m;i+4-)
jf(j%7==0||i%U==0)
(
aD]=I;
j++;
}
*n=j;
}
28:第28题请编写一种函数fun,它日勺功能是:找出一维整型数组元素中最大
的值和它所在H勺1标,最大H勺值和它所在H勺下标通过形参传回。数组元素中H勺值
己在主函数中赋予。主函数中x是数组名,n是x中的数据个数,max寄存最大
值,index寄存最大值所在元素的下标。
答案:
voidfun(inta[],intnzint*maxzint*d)
{
intI;
*max=a[0];
*d=0;
for(i=0;I<n;i++)
if(a[i]>*max)
{
*max=a[i];
*d=I;
)
}
29:第29题请编写一种函数fun,它的功能是:将ss所指字符串中所有下标为
奇数位置上H勺字母转换为大写(若该位置上不是字母,则不转换)。
答案:
voidfun(char*ss)
(
intI,n;
n=strlen(ss);
for(i=l;i<n;i+=2)
if(ss[i]>='a/&ass[i]<=Y)
ss[i]=ss[i]-32;
)
30:第30题请编写一种函数fun,它的功能是:求除一种2xm整型一维数组
中最大元素H勺值,并将此值返回调用函数。
答案:
intfun(inta[][M])
(
intIj,max;
max=a[0][0];
for(i=0;i<2;i++)
for(j=0;j<M;j++)
if(a[i]0]>max)
max=a[i][j];
returnmax;
)
31:第31题请编写函数fun,其功能是:将s所指字符串中除了下标为偶数、
同步ascii值也为偶数口勺字符外,其他口勺全都删除;串中剩余字符所形成的一种
新串放在t所指口勺一种数纽中。
答案:
voidfun(char*s,chart[])
intIzj=Ozn;
n=strlen(s);
for(i=0;Izn;i++)
if(i%2==0&&s[i]%2==0)
{
t[j]=s[i];
j++;
}
tU]='\oz;
)
32:第32题请编写函数fun,其功能是:将s所指字符串中除了下标为奇数、
同步ascii值也为奇数口勺字符之外,其他口勺所有字符都删除,串中剩余字符所形
成的一种新串放在t所指的一种数组中.
答案:
voidfun(char*szchart[])
(
intI,j=Ozn;
n=strlen(s);
for(i=0;Izn;i++)
if(i%2!=0&&s[i]%2!=0)
tU]=s[i];
j++;
)
t[j]='\(r;
}
33:第33题假定输入的字符串中只包括字母和*号。请编写函数fun,它H勺功能
是:使字符串中尾部的*号不得多于n个;若多于n个,则删除多于的*号;若少
于或等于n个,则什么也不做,字符串中间和前面的*号不删除。
答案:
voidfun(char*a,intn)
{
inti=0;k=0;
char*p,*t;
P=t=a;
while(*t)
t++;
t-;
while(*t=='*9
{
k++;
t-;
)
t++;
if(k>n)
{
while(*p&&p<t+n)
{
a[i]=*P;
i++;
P++;
}
a[i]='\O/;
}
)
34:第34题学生的J记录由学号和成绩构成,n名学生的数据已在主函数中放入
构造体数组s中,请编写函数fun,它H勺功能使:把分数最高的学生数据放在h
所指的数组中,注意:分数最高的学生也许不止一种,函数返回分数最高口勺学生
的人数c
答案:
intfun(STREC*a,STREC*b)
(
intIj=Ozn=O,max;
max=a[O].s;
for(i=0;i<N;i++)
if(a[i].s>max)
max=a[i].s;
for(i=0;i<N;i++)
if(a[i].s==max)
(
*(b+j)=a[i];
j++;
n++;
}
returnn;
}
35:第35题请编写一种函数,用来删除字符串中的所有空格。
答案:
voidfun(char*str)
(
inti=0;
char*p=str;
while(*p)
{
if(*p!=w)
{
str[i]=*p;
i++;
)
p++;
)
str[i]='\Oz;
)
36:第36题假定输入的字符串中只包括字母和*号。请编写函数fun,它H勺功能
是:将字符串中的前导*号所有移到字符串的尾部。
答案:
voidfun(char*a)
(
inti=0,n=0;
char*p;
P=a;
while(*p=='*")
(
n++;
p++;
)
while(*p)
(
a[i]=*p;
i++;
P++;
}
while(n!=0)
a[i]='*z;
i++;
n-;
}
a[i]='\CT;
}
37:第37题某学生的记录山学号、8门课程成绩和平均分构成,学号和8门课
程的J成绩已在主函数中给出。请编写函数fun,它口勺功能是:求出该学生日勺平均
分放在记录时ave组员中。请自己定义对啊啊形参。
答案:
voidfun(STREC*p)
(
doubleav=0.0;
inti:
for(i=0;i<N;i++)
av+=p->s[i];
av/=N;
p->ave=av;
}
38:第38题请编写函数fun,它的功能是:求出ss所指字符串中指定字符H勺个
数,并返回此值。
答案:
intfun(char*ss,charc)
{
intn=0;
while(*ss)
{
if(*ss==c)
n++;
ss++;
)
returnn;
}
39:第39题请编写函数fun,该函数口勺功能是:移动一维数组中的内容,若数
组中由n个整数,规定把下标从0到p(p不不小于等于n-1)时数组元素平移到
数组的最终。
答案:
voidfun(int*w,intpzintn)
{
intb[N],i,j=0;
for(i=0;i<=p;i++)
b[i]=w[i];
j++;
}
for(i=0;i<=p;i++)
{
wD]=b[i];
j++;
}
}
40:第40题请编写函数fun,该函数日勺功能是移动字符串中内容,移动的I规则
如下:把第1到第m个字符,平移到字符串日勺最终,把第m+1到最终日勺字符移
到字符串H勺前部。
答案:
voidfun(char*wzintm)
(
charb[N];
intIj=0;
for(i=0;i<m;i++)
(
bU]=w[i];
j++;
}
for(i=0;i<strlen(w)-m;i++)
w[i]=w[i+m];
for(j=0;j<m;j++)
w[i]=b[j];
i++;
}
w[i]='\Oz;
}
41:第41题请编写函数fun,该函数的功能是:将m行n列的)二维数组中口勺字
符数据,按列时次序依次放到一种字符串中。
答案:
voidfun(char(*s)[n]zchar*b)
{inti,j,k=O;
for(j=0;jvn;j++)
for(i=0;i<m;i++)
{b[k]=*(*(s+i)+j)
k++;>
b[k]='\Oz;}
42:第42题下列程序定义了nxn的二维数组,并在主函数中自动赋值。请编
写函数fun(inta[][n]zintn),该函数的功能是:将数组右上半三角元素中日勺值乘
以m。
答案:
voidfun(inta[][n]zintm)
{inti,j;
for(j=O;j<n;j++)
for(i=0;i<=j;i++)
aO]=a[j]*m;}
43:第43题编写一种函数,从传入的num个字符串中找出一种最长H勺一种字
符串,并通过形参指针max传回该串地址(用****作为结束输入H勺标志)。
答案:
char*fun(char(*a)[81]zintnum)
{inti;
char*max;
max=a[0];
for(i=0;i<num;i++)
if(strlen(max)<strlen(a))
max=a;
returnmax;}
44:第44题编写一种函数,该函数可以记录一种长度为2的字符串在另一种字
符串中出现H勺次数。
答案:
intfun(char*strzchar*substr)
{intn;
char*p,*r;
n=0;
while(*str)
{P=str;
r=substr;
while(*r)
if(*r==*p)
{r++;
P++;}
else
break;
if(*r=='\oz)
n++;
str++;}
returnn;}
45:第45题假定输入的字符串中只包括字母和*号.请编写函数fun,它的功能
是:只删除字符串前导利尾部由J*号,串中字母之间小J*号都不删除。形参n给出
了字符串口勺长度,形参h给出了字符串中前导*号的个数,形参e给出了字符串
中最终H勺*个数。在编写时不得使用c语言给提供得字符串函数。
答案:
voidfun(char*a,intn,inthjnte)
{inti=0;
char*p;
for(p=a+h;p<a+n-e;p++)
{*(a+i)=*p;
i++;}
*(a+i)='\O';}
46:第46题学生得记录由学号和成绩组称个,n名大学生得数据已在主函数中
放入构造体数组s中,请编写函数fun,它的功能时:按分数的高下排列学生的
记录,高分在前。
答案:
voidfun(streca[])
{inti,j;
strect;
for(i=0;i<n-l;i++)
for(j=i;s<n;j++)
if(a.s<a[j].s)
{t=a;
a=a[j];
aD]=t;}}
47:第47题请编写一种函数voidfun(cha「*ss),其功能时:将字符串ss中所
有下标为奇数位置上的字母转换为大写(若位置上不是字母,则不转换)。
答案:
voidfun(char*ss)
{inti,n=0;
char*p=ss;
while(*p)
{n++;
P++;}
for(i=0;i<n;i++)
if((ss='a/&ss<='zz)&i%2'=0)
ss=ss-32;
ss='\Oz;}
48:第48题请编写函数fun,其功能是:将两个两位数的正整数a,b合并成一
种整数放在c中。合并日勺方式是:将a数的十位和个位依次放在c数的千位和I-
位上,b数的)十位和个位数依次放在c数的百位和个位二。
答案:
voidfun(inta,intbjong*c)
{*c=(a/10)*1000+(b/10)*100+(a%10)*10+b%10;}
49:第49题请编写函数fun,其功能是:将s所指字符串中下标位偶数同步
ascii值为奇数的字符删除,s中剩余的字符形成的新串放在t所指H勺数组中。
答案:
voidfun(char*szchart[])
{inti,j=Ozn=strlen(s);
for(i=0;i<n;i++)
if(i%2==0&s%2!=0)
else
{f[j]=s;
j++;}
t[j]='\O';}
50:第50题已知学生的记录是由学号和学习成绩构成,n名学生H勺数据已存入
a机构体数组中。请编写函数fun,该函数H勺功能是:找出成绩最高日勺学生记录,
通过形参返回主函数(规定只有•种最高分)。
答案:
voidfun(stua[],stu*s)
{inti,max;
max=a[0].s;
for(i=0;i<n;i++)
if(a.s>max)
{max=a.s;
*s=a;})
第51题请编写函数fun,其功能是:将所有不小于1天不小于整数m『、j非素数
存入xx所指的数组中,非素数H勺个数通过k传回。
答案:
voidfun(intmzint*k,intxx[])
{inti,j;
intt=0;
for(i=2;i<m;i++)
(j=2;
while(j<i)
{if(i%j==O)
{xx[t]=i;
t++;
break;}
j++;}
*k=t;}}
52:第52题编写一种函数fun,它口勺功能是:实现两个字符串的连接(不使用库
函数strcat),即把p2所指的I字符串连接到pl所指口勺字符串后。
答案:
voidfun(charpl[],charp2[])
{inti=0zn=0;
char*p=plz*q=p2;
while(*p)
{P++;
n++;)
i=n;
while(*p)
{pi=*q;
q++;
i++;}
P1='\O';}
53:第53题请编写函数fun,该函数H勺功能是:实现b=a+a,即把矩阵a加上a
时转置,寄存在矩阵b中。计算成果在main函数中输出。
答案:
voidfun(inta[3][3]Jntb[3][3])
{intij,at[3][3];
for(i=0;i<=2;i++)
for0=0;j<=2;j++)
atU]=a[j];
for(i=0;i<3;i++)
for0=0;j<3;j++)
bU]=aU]+atQ];}
54:第54题学生的记录由学号和成绩组称个,n名学生的数据已在主函数中放
入构造体数组s中,请编写函数fun,它的功能是:把低于平均分的J学生数据放
在b所指的数组中,低于立均分的学生人数通过形参n传回,平均分通过函数值
返回。
答案:
doublefun(strec*a,strec*b,int*n)
{doubleaver=0.0;
intij=0;
*n=0;
for(i=0;i<n;i++)
aver+=a.s;
aver/=n;
for(i=0;i<n;i++)
if(a.s<aver)
{bD]=a;
(*n)++;
j++;}
returnaver;}
55:第55题请编写函数fun,该函数的J功能是:将m行n列的二维数组中口勺数
据,按行的次序依次放到一维数组中,一维数组中数据的个数寄存在形参n所指
的储存单元中。
答案:
voidfun(int(*s)[10],int*bjnt*nzintmmjntnn)
{inti,j;
for(i=0;i<mm;i++)
for(j=0;j<nn;j++)
{b[*n]=*(*(s+i)+j);
*n=*n+l;}}
56:第56题假定输入的字符串中只包括字母和*号。请编写函数fun,它的功能
是:除了尾部小户号之外,将字母串中其他*号所有删除。形参p已指向字符串中
最终H勺一种字母。不使用cH勺字符串函数。
答案:
voidfun(char*azchar*p)
{inti=0;
char*p=a;
while(q<=p)
{if(*q!='*')
{a=*q;
i++;}
q++;}
while(*q)
{a=*q;
i++;
q++;}
a='\0';}
57:第57题学生rJ记录是由学号和成绩构成,n名学生的数据已在主函数中放
入构造体数组s中,请编写函数fun,它口勺功能是:把指定分数范围内的学生数
据放在b所指H勺数组中,分数范围内H勺学生人数由函数值返回。
答案:
intfun(strec*a,strec*b,intI,inth)
{inti,j=0;
for(i=0;i<n;i++)
if(a.s>=l&a.s<=h)
{bU]=a;
j++;}
returnj;}
58:第58题编写函数藏服那,它时功能是:求n以内(不包括n)同步能被3与7
整除H勺所有自然数之和的平方根s,并作为函数值返回c
答案:
doublefun(intn)
{doubles=0.0;
inti;
for(i=l;i<n;i++)
if(i%3==0&i%7==0)
s=s+i;
s=sqrt(s);
returns;}
59:第59题请别写函数fun,该函数H勺功能是:将放在字符串数组中的Jm个字
符串(每串H勺长度不超过n),按次序合并构成一种新H勺字符串。
答案:
voidfun(chara[m][n]zchar*b)
{inti,j,k=O;
for(i=0;i<m;i++)
{for(j=0;j<n;j++)
if(*(*(a+i)+j))
{b[k]=*(*(a+i)+j)
k++;}
else
break;
b[k]='\O";}}
60:第60题请编写函数fun,该函数H勺功能是:删去•维数组中所有相似的数,
使之只剩一种。数组中口勺数已按山小到大的次序排列,函数返回删除后数组中数
据的个数。
答案:
intfun(inta[]Jntn)
{intiztj=0/*p=a;
t=p[0];
for(i=0;i<=n;i++)
if(t==P)
else
{aU]=t;
t=p;
j++;)
if(i>=n)
returnj;}
61:第61题第请编写函数fun,该函数H勺功能使:记录各年龄段的人数。N个
年龄通过调用随机函数获得,并放在主函数口勺age数组中;规定函数把。至9岁
年龄段的人数放在d[0]中,把10至19岁年龄段口勺人数放在d[l]中,把20至29
岁啊人数放在d[2]中,其他以此类推,把100岁(含100以上年龄的人数都放在
仇10]中。成果在主函数中输出。
答案:
voidfun(int*azint*b)
{inti,j;
for(j=0;i<m;j++)
bU]=O;
for(i=0;i<n;i++)
if(a>=0&a<=9)
b[0]+=l;
elseif(a>=10&a<=19)
b[l]+=l;
elseif(a>=20&a<=29)
b[2]+=l;
elseif(a>=30&a<=39)
b[3]+=l;
elseif(a>=40&a<=49)
b[4]+=l;
elseif(a>=50&a<=59)
b[5]+=l;
elseif(a>=60&a<=69)
b[6]+=l;
elseif(a>=70&a<=79)
b[7]+=l;
elseif(a>=80&a<=89)
b网+=1;
elseif(a>=90&a<=99)
b[9]+=l;
else
b[10]+=l;}
62:第62题请编写函数fun,该函数H勺功能是:统一一含字符串中单词的个数,
作为函数值返回。一行字符串在主函数中输入,规定所有单词由小写字母构成,
单词之间由若干个空格格开,一行H勺开始没有空格。
答案:
intfun(char*s)
{intizn=O;
for(i=0;i<strlen(s);i++)
{if(s=a,&s<=Y&s[i+l]==w
IIs[i+l]=='\Oz)
n++;}
returnn;}
63:第63题请编写一种函数fun,它H勺功能是:计算并输出给定整数n的所有
因子(不包括1与自身)之和。规定nH勺值不不小于100,
答案:
intfun(intn)
{ints=0,i;
for(i=2;i<=n-l;i++)
if(n%i==0)
s+=i;
returns;}
64:第64题请编写函数fun,其功能是:将s所指字符串中ascii值为奇数的字
符删除,串中剩余字符形成一种新串放在t所指的数组中。
答案:
voidfun(char*szchart[])
{intij=0,n;
n=strlen(s);
for(i=0;i<n;i++)
if(s%2==0)
{tU]=s;
j++;}
tU]=\oz;}
65:第65题请编写函数fun,其功能是:将两位数H勺正整数a、b合并成一种整
数放在c中。合并H勺方式是:将a数内I十位和个位数依次放在c数R勺百位和个位
上,b数的十位和个位数依次放在c数的十位和千位上。
答案:
voidfun(inta,intbjong*c)
{*c=(b%10)*1000+(a/10)*100+(b/10)*10+a%10;)
66:第66题假定输入的字符串中只包括字母和*号。请编写函数fun,它H勺功能
是:删除字符串中所有*号。在编写函数时,不得使用c语言提供的字符串函数。
答案:
voidfun(char*a)
{inti=0;char*p=a;
while(*p)
{if(*p!='*/)
{a=*P;
i++;}
P++;}
a='\0';}
67:第67题学生的记录时由学号和成绩构成,n名学生的数据已在主函数中放
入构造体数组s中,请编写函数fun,它口勺功能时:函数返回指定学号的学生数
据,指定的学号在主函数中输入。若没找到指定学号,在构造体变量中给学号置
空串,给成绩置作为函数值返回(用于字符串比较的函数时strcmp)。
答案:
strecfun(strec*,char*b)
{inti;
strech;
for(i=0;i<n;i++)
if(strcmp(a.numzb)==O)
{h=a;
break;}
else
{h.num=="";
h.s=-l;}
returnh;}
68:第68题请编写函数fun,其功能时:计算并输出k列多项式的值:
sn=l+l/l!+l/2!+l/3!+l/4!+--+l/n!
答案:
sn=l+l/l!+l/2!+l/3!+l/4!+...+l/n!
doublefun(intn)
{doublet,sn=1.0;
inti,j;
for(i=l;i<n;i++)
{t=i.o;
for(j=l;j<=i;j++)
sn+=1.0/t;}
returnsn;}
69:第69题请编写一种函数fun,它口勺功能时:求Fibonacci数列中不小于t的
最小的一种数,成果由函数返回。其中Fibonacci数列f(nW、j定义为:
f(0)=0zf(l)=lzf(n)=f(n-l)+f(n-2)
答案:
f(0)=0,f(l)=l,f(n)=f(n-l)+f(n-2)
intfun(intt)
{inta=lzb=l,c=Ozi;
for(i=4;i<=t;i++)
{if(c<t)
{c=a+b;
a=b;
b=c;}
else
break;}
returnc;}
70:第70题编写函数fun,它口勺功能时:计算并输出二列级数和:
s=1/1*2+1/2*3+…+l/n(n+l)
答案:
doublefun(intn)
{doubles=0.0;
inti;
for(i=l;i<=n;i++)
s=s+1.0/(i*(i+l));
returns;}
71:第71题请编写函数fun,其功能时:将两个两位数的正整数a、b合并形成
一种整数放在c中,合并的方式是:将a数口勺十位和个位数依次放在c数的J十位
和千位上,b的十位和个位整数依次放在c数的百位和个位.匕
答案:
voidfun(intajntbjong*c)
{*c=(a%10)*1000+(b/10)*100+(a/10)*10+b%10;}
72:第72题请编写函数fun,其功能是:将s所指字符串中下标为偶数的字符
删除,串中剩余字符形成新串放在t所指数组中。
答案:
voidfun(char*s,chart口)
{inti,j=O/n=strlen(s);
for(i=0;i<n;i++)
if(i%2!=0)
{tU]=s;
j++;}
tU]=\oz;}
73:第73题假定输入的I字符串中只包括字母和*号,请编写函数fun,它的功能
是:除了字符串前导和尾部的*号之外,将串中其他*号所有删除。形参h已指向
字符串第一种字符,形参p已指向字符串中最终一种字母。在编写程序时,不得
使用c语言提供H勺字符串函数。
答案:
voidfun(char*a,char*hzchar*p)
{inti=0;
char*q=a;
while(q<h)
{a=*q;
q++;
i++;}
while(q<p)
{if(*q!=、,*)
{a=*q;
i++;}
q++;}
while(*q)
{a=*q;
i++;
q++;}
a='\Oz;}
74:第74题学生的记录日学号和成绩构成n名学生的数据已在主函数中放入构
造体数组s中,请编写函数fun,它的功能时:把分数最低的学生数据放在h所
指H勺数组中,注意:分数最低的学生也许不止一种,函数返回分数最低H勺学生的
人数。
答案:
intfun(strec*a,strec*b)
{inti,j=O,n=O,min;
min=a[O].s;
for(i=0;i<n;i++)
if(a.s<min)
min=a.s;
for(i=0;i<n;i++)
if(a.s==min)
{*(b+j)=a;
j++;
n++;}
returnn;}
乃:第75题请编写函数fun,该函数的功能:将m行n列日勺二维数组中的数据,
按列H勺顺学依次放到一维数组中。
答案:
voidfun(int(*s)[]10zint*b,int*nzintmmjntnn)
{inti,j;
for(j=0;j<nn;j++)
for(i=0;i<mm;i++)
{b[*n]=*(*(s+i)+j);
*n=*n+l;}}第76题请编写函数fun,其功能时:计算并输出当xv0.97时下列
多项式的值,直到Isn-s(n-l)I<0.000001为止。
Sn=l+0.5x+0.5(0.5-l)/2!x(2)+-+0.5(0.5-l)(0.5-2)-..(0.5-n+l)/n!x(n)
答案:
.doublefun(doublex)
{doublesl=1.0,p=1.0zsum=0.0zs0,t=1.0;
intn=l;
do
{s0=sl;
sum+=s0;
t*=n;
p*=(0.5-n+l)*x;
sl=p/t;
n++;}while(fabs(sl-s0)>le-6);
returnsum;}
77:第77题请编写一种函数fun,其功能是:将两个两位数的正整数ab合并形
成一种整数放在c中。合并方式是:将a数的十位和个位数依次放在c数H勺个位
和百位上,b数的十位和个位数依次放在c数H勺十位和千位上。
答案:
voidfun(inta,intbjong*c)
{*c=(b%10)*1000+(a%10)*100+(b/10)*10+a/10;}
78:第78题请编写函数fun,其功能是:将s所指字符串中ascii值为偶数H勺字
符删除,串中剩余字符形成•种新串放在t所指H勺数组中。
答案:
voidfun(char*szchart[])
{intiJ=O,n=strlen(s);
for(i=0;i<n;i++)
if(s%2!=0)
{tU]=s;
j++;}
tg'\02
79:第79题己知学生的记录由学号和学习成绩构成,n名学生的数据己存入a
构造体数组中。请编写函数fun,该函数H勺功能是:找出成绩最低的学生记录,通
过形参返回主函数(规定只有一种最低分)。
答案:
voidfun(stua[],stu*s)
{inti,min;
min=a[O].s;
for(i=0;i<n;i++)
if(a.s<min)
{min=a.s;
*s=a;})
80:第80题程序定义了nxn的二维数组,并在主函数中自动赋值。请编写函
数fun,该函数的功能是:使数组左下半三角元素中的值乘以no
答案:
fun(inta[][n]zintn)
{intij;
for(i=0;i<n;i++)
for0=O;j<=i;j++)
aU]=a[j]*n;}
81:第81题请编写函数fun,其功能使:将两个两位正整数ab合并形成一种
整数放在c中。合并口勺方式使:将a数的十位和个位数依次放在c数的百位和个
位上,b数的十位和个位数依次放在c数的千位和十位二。
答案:
voidfun(inta,intb,long*c)
{*c=(b/10)*1000+(a/10)*100+(b%10)*10+a%10;}
82:第82题请编写一种函数fun,它H勺功能使:计算n门课程H勺平均分,计算
成果作为函数值返回。
答案:
floatfun(float*a,intn)
{floatave=0.0;
inti;
for(i=0;i<n;i++)
ave+=a;
ave/=n;
returnave;}
83:第83题假定输入的字符串中只包括字母和*号。请编写函数fun,它R勺功能
使:将字符串尾部的*号所有删除,前面和中间H勺*号不删除。
答案:
voidfun(char*a)
{inti=0;
char*p,*q;
p=q=a;
while(*p)
P++;
P-;
while(*p=='*z)
P-;
while(q<=p)
{a=*q;
i++;
q++;}
a='\Oz;}
84:第84题请编写函数fun,其功能是:将两个两位数的正整数db合并形成
一种整数放在c中,合并的方式是:将d数H勺十位和个位数依次放在c的个位和
百位上,b数的十位和个位数依次放在c数的千位和十位上。
答案:
voidfun(intazintb,long*c)
{c=(b/10)*1000+(a%10)*100+(b%10)*10+a/10;}
85:第85题n名学生H勺成绩已在主函数中放入一种带头节点H勺链表构造中,h
指向链表口勺头节点。请编写函数fun,它的功能是:求出平均分,由函数值返回。
答案:
doublefun(strec*h)
{doubleaver=0.0;
while(h!=null)
{aver+=h->s;
hy=h->next;}
aver/=n;
returnaver;}
86:第86题请编写函数fun,计算并输出给定10个数H勺方差。
答案:
doublefun(doublex[10])
{intij;
doubles=0.0zsl=0.0;
for(i=0;i<10;i++)
sl+=x;
sl/=10;
for(j=0;j<10;j++)
s+=(xU]-sl)*(x[j]-sl);
s/=10;
s=pow(sz0.5);
returns;}
87:第87题请编写函数fun,其功能是:将两个两位数的正整数ab合并形成
一种整数放在c中。合并H勺方式是:将a数的十位和个位数依次放在c数口勺千位
和十位上,b数的十位和个位数依次放在c数的个位和百位上。
答案:
voidfun(inta,intb,long*c)
{*c=(a/10)*1000+(a%10)*10+(b%10)*100+b/10;}
88:第88题假定输入的字符串中只包括字母和*号。请编写函数fun,它R勺功能
是:除了字符串前导的*号之外,将串中其他*号所有删除。在编写函数亚时,不
得使用c语言提供的字符串函数。
答案:
voidfun(char*a)
{inti=0;
char*p=a;
while(*p&&*p=='*9
{a=*p;
i++;
P++;)
while(*p)
{if(*p!='*z)
{a=*P;
i++;}
P++;}
a='\0';)
89:第89题学生的记录是由学号和成绩构成,n名学生的数据已在主函数中放
入构造体数组s中,请编写函数fun,它日勺功能是:把高于等于平均分的学生数
据放在b所指的数组中,高于等于平均分口勺学生人数通过形参n传回,平均分通
过函数值返回。
答案:
doublefun(strec*azstrec*bzint*n)
{doubleaver=0.0;
intij=0;
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024东航物流客服岗面试高频题及服务类问题标准答案
- 2020山东医专单招押题卷试题及答案 押中率超80%
- 2020年幼儿养育照护语言启蒙考点试题及标准答案
- 2021年物业服务中心半结构化面试题库及满分答案
- 2021铁塔代维日常巡检考试真题及官方标准答案
- 2021铁塔代维电源系统维护考试专项试题及答案
- 2024上海事业单位考试历年真题+常识考点速记
- 2022年库伦分析法期末考试押题卷及官方参考答案
- 江苏泰州市姜堰区实验初级中学2025-2026学年下学期九年级数学第一次独立作业(含解析)
- 太阳能安装运维协议书
- 蔬果采购员管理制度
- 2026年广州市高三语文一模作文题目解析及范文:那些被遗忘的后半句
- 广东省广州市黄埔区第八十六中学2024-2025学年八年级下学期4月期中物理试题(含答案)
- 贵州省六盘水市英武水库工程环评报告
- 残疾学生送教上门备课、教案
- JTGT F20-2015 公路路面基层施工技术细则
- 保洁礼节礼仪培训
- 土建劳动力计划表劳动力安排计划及劳动力计划表
- 天然气加工工程轻烃回收课件
- 英语四级长篇匹配阅读练习题
- 健康管理师资料:《健康管理师》 国家职业资格培训介绍
评论
0/150
提交评论