C语言程序填空题文档格式.docx
《C语言程序填空题文档格式.docx》由会员分享,可在线阅读,更多相关《C语言程序填空题文档格式.docx(43页珍藏版)》请在冰豆网上搜索。
s二s十t:
2;
printf("
%d\n"
s):
【3.5】有以下程序段:
s=l.0;
for(k=l;
k<
=n;
k++)
s=s+l.0/(k*(k+l)):
%f\n"
填空完成下述程序,使之与上述程序的功能完全相同。
s=0.0:
k=0;
do
{s二s+d;
d=1.0/(k*(k+l));
}while(③);
【3.6】下面程序的功能是从键盘上输入若干学生的学习成绩,统计并输出最高成绩和最低成绩,当输入为负数时结束输入。
{floatx,amax,amin:
%f"
x);
amax=x:
amin=x;
while(①)
{if(x>
amax)amax=x;
if(②)amin=x:
scanf("
printf(,z\namax=%f\namin=%f\n,z,amax,amin):
(3.7】下而程斥的功能是将形参x的值转换为二进制数,所得的二进制数放在一个一维数组中返回,二进制数的最低位放在下标为0的元素中。
fun(intx,intb[])
{intk=0,r;
{r=x%①;
b[k++]=r;
x/=②;
}while(x):
[3.8]下面程序的功能是输出1到100之间每位数的乘积大丁每位数的和的数。
例如数字26,数位上数字的乘积12大于数字之和8O
{intn,k=l,s=0,m:
for(n=l:
n<
=100:
n++)
{k=l:
s=0:
while(②)
{k*=m%10;
s+=m%10;
3;
if(k>
s)
printfn):
[3.9]下面程序的功能是统计用0至9之间的不同的数字组成的三位数的个数。
{inti,j,k,count二0;
=9;
£
or(j=0;
j<
j++)
if(①)continue;
elsefor(k=0;
if(②)count++;
printf("
count):
[3.10]下而程序的功能是输出100以内的个位数为6、且能被3整除的所有数。
{inti,j;
①;
i++)
{j=i*10+6;
if(②)countinue:
printfj):
【3.11】下面程序的功能是用辗转相除法求两个正整数m和n的最大公约数。
hcf(intm,intn)
{intr;
if(m<
n)
{r=m:
①:
n=r;
r=m%n:
{m=n;
【3.12】下而程序的功能是使用冒泡法对输入的10个浮点数从小到大进行排序。
排好序的10个数分两行输出。
程序如下:
★include<
{①;
inti,j;
printf("
Input10numbersplease'
n"
);
②:
i++)
scanf(*%f&
\n"
);
for(i=2;
③;
for(j=0;
④;
j++)
if(⑤)
{x=a[j];
⑥;
a[j+l]二x:
Thesorted10numbers;
\n"
for(i=0:
⑦;
{迁(⑧)
printfa[i]);
[3.13】下面程序的功能是读入20个整数,统计非负数个数,并计算非负数之和。
^include"
stdio.h"
{inti,a[20],s,count:
s=count=0:
20;
i++)
scanf①):
{迁(a[i]<
0)
s+二a[i];
count++;
s=%d\tcount=%d\n"
s,count);
[3.14]下面程序的功能是删除字符串s中的空格。
:
、char*s=z,Beijingligongdaxue"
;
for(i=j=0;
s[i]!
='
\0'
辻(s[i]!
=…)①;
else②;
s[j]='
【3.15】下面程字的功能是将字符串s中所有的字符'
c'
删除。
请选择填空。
ttinclude<
{chars[80]:
gets(s);
='
\0'
if(s[i]!
二’c'
)①:
puts(s);
【3.16】下面程序的功能是输出两个字符串中对应相等的字符。
ttinclude<
charx一二"
pro呂ramming"
:
chary[]="
Fortran"
{inti=0;
while(x[i]!
二’\0'
&
&
y[i]!
)
if(x[i]=y[i])
%c"
①);
else
i++;
[3.17]下面程序的功能是将字符串s中的每个字符按升序的规则插到数组a中,字符串a己排好序。
string.h>
main()
{chara[20]=,,cehiknqtw,/:
chars[]="
fbla"
inti,k,j:
for(k=0;
s[k]!
k++)
{j=0:
while(s[k]>
=a[jl&
a[j]!
=*\Q9)
+r
.J+fo②
puts(a):
[3.18]下面程序的功能是对键盘输入的两个字符串进行比较,然后输出两个字符串中第一个不相同字符的ASCII码之差。
例如:
输入的两个字符串分别为"
abcdefg"
和"
abceef"
则输出为T。
^include<
{charstrl[100],str2[100],c;
inti,s;
Enterstring1:
”);
gets(strl):
Enterstring2:
gets(str2);
i=0:
while((strl[i]==str2[i]&
strl[i]!
=①))
s=②:
s);
[3.19]下面的函数expand在将字符串s复制到字符串t时,将其中的换行符和制表符转换为可见的转义字符表示,即用’\n表示换行符,用'
\t'
表示制表符。
expand(chars[],chart[])
for(i=j=0:
switch(s[i])
{case'
\n'
:
t[①]二②;
t[j”]=;
break:
case'
\t'
t[③]二④;
t[j++]二'
t'
;
default:
t[⑤]二s[i];
t[j]=⑥;
【3.20】卜面的函数index(chars[],chart[])检查字符串s中是否包含字符串t,若包含,则返回t在s中的开始位置(下标值),否则送回-1。
index(chars[],chart[])
{inti,j,k:
s[i]!
{for(j=i,k=0;
①&
s[j]=t[k];
j++,k++);
if(②)
return(i):
return(~1):
【3.21】下面程序的功能是计算S二k!
o
k=0
longfun(intn)
{inti;
longs;
i①;
s*二i:
main()
{intk,n;
longs:
n):
s=③:
for(k=0;
s+=④;
printfs):
[3.22]下面程序的功能是显示具有n个元素的数组s中的最大元素。
ttdefineN20
{inti,a[N];
N:
scanf&
a[i]):
fmax(intsEl,intn)
{intk,p;
for(p=0,k=p:
n;
if(s[p]>
s[kl)②;
return(k):
【3.23]下面程序的功能是由键盘输入m求满足下述条件的x、y:
nx和ny的末3位数字相同,且xHy,x、y、n均为自然数,并使x+y为最小。
nclude<
pow3(intn,intx)
{inti,last;
for(last二1,i二1;
=x;
last=①:
return(last):
{intx,n,min,flag=l;
seanf(”%d:
n);
for(min=2;
flag:
min++)
for(x=l;
x<
min&
x++)
辻(②&
pow3(n,x)==pow3(n,min~x))
{printfC*x=%d,y=%d\n"
x,min-x):
[3.24]下面的程序是用递归算法求a的半方根。
求平方根的迭代公式如下:
doublemysqrt(doublea,doublexO)
{doublexl,y:
xl二①;
if(fabs(xl-xO)>
0.00001)
y=mysqrt(②);
elsey=xl;
return(y):
{doublex;
Enterx:
”):
scanf&
x):
Thesqrtof%lf=%lf\n"
x,mysqrt(x,1.0)):
[3.25]以下程序是计算学生的年龄。
已知第一位最小的学生年龄为10岁,其余学生的年龄一个比一个大2岁,求第5个学生的年龄。
age(intn)
{intc;
if(n==l)c=10:
elsec=①;
return(c):
{intn=5:
printf(*age:
%d\n*,②);
【3.26】下面的函数sum(intn)完成计算1〜n的累加和。
sumdntn)
{if(n<
=0)
dataerror\n,z):
辻(n==l)①;
[3.27]下面的函数是一个求阶乘的递归调用函数。
facto(intn)
{if(n==1)①;
elsereturn(②);
[3.28】组介问题,由组合的基本性质可知:
(1)C(m,n)=C(n~m,n)
(2)C(m,n+1)=C(m,n)+C(m-1,n)
公式
(2)是一个递归公式,一直到满足C(l,n)=n为止。
当n〈2*m时,可先用公式
(1)进行简化,填写程序中的空白,使程序可以正确运行。
ttincludez/stdio.h"
{intm,n;
Inputm,n二"
scanf(”%d%d"
m,&
Thecombinationnumbeersis%d\n"
combin(m,n)):
combin(intm,intn)
、intcom:
if(n<
2*m)m=n-m:
if(m==0)com=l;
elseif(m==l)①;
else②:
return(com);
【3.29】下列函数是求一个字符串str的长度。
intstrlen(char*str)
{辻(①)return(0):
elsereturn(②);
[3.30】用递归实现将输入小于32768的整数按逆序输岀。
如输入12345,则输出54321。
#include"
{intn:
Inputn:
"
scanf①);
r(n);
):
r(intm)
{printf②):
m二③;
if(④)
⑤;
[3.31】输入n值,输出高度为n的等边三角形。
例如当n=4时的图形如下:
*
***
*****
voidprt(charc,intn)
{if(n>
0)
{printf("
c):
{inti,n;
for(i=l:
{②:
[3.32】下面的函数实现N层嵌套平方根的计算。
doubley(doublex,intn)
{if(n==0)
return(0):
elsereturn(sqrt(x+(①)));
[3.33】函数revstr(s)将字符串s置逆,如输入的实参s为字符串"
abcde"
则返回时s为字符串"
edcba"
。
递归程序如下:
revstr(char*s)
{char*p=s,c;
while(*p)p++:
辻(s<
p)
{c=*s;
*s=*p:
revstr(s+1);
如下是由非递归实现的revstr(s)函数:
revstr(s)
char*s;
{char*p=s,c:
while(*p)p++:
4;
while(s<
p)
{c=*s:
5二*p;
*p―=c;
[3.34]下面函数用递归调用的方法,将str中存放的长度为n的字符串反转过来,例如原来是"
ABCDE"
反斥为“EDCBA"
voidinvent(char*str,intn)
{chart;
t=*str:
*str=*(str+n-l):
*(str+n~l)=t:
if(n>
2)invent(①,n~2):
else②:
[3.35]从键盘上输入10个整数,程序按降序完成从大到小的排序。
intarray[10]:
sort(int*p,int*q)
{int*max,*s;
if(①)
return:
max二p;
for(s二p+1:
s<
=q;
s++)
辻(*s>
*max)
swap(③);
sort(④);
swap(int*x,int*y){inttemp:
temp=*x:
*x=*y:
*y=temp;
Enterdata:
):
for(i=0:
10:
scanf("
array[i]):
sort(⑤);
Output:
for(i=0:
printf(*%d”,arrayEi]);
[3.36】下面函数的功能是将一个整数存放到一个数组中。
存放时按逆斥存放。
例如:
483存放成"
384"
voidconvert(char*a,intn)
辻((i=n/10)!
=0)
convert(①,i);
二②;
charstr[10]="
”;
{intnumber:
number);
convert(str,number):
puts(str):
[3.37】下面程斥的功能是实现数组元素中值的逆转。
string・h>
{inti,n=10,a[10]={l,2,3,4,5,6,7,&
9,10};
invert(a,n~l):
%4d"
a[i]);
invert(int*s,intnum)
{int*t,k;
t=s*num:
{k=*s;
*s=*t:
*t=k;
②;
3:
【3.38】下面程序通过指向整型的指针将数组a[3][4]的内容按3行X4列的格式输出,请给printf()填入适当的参数,使之通过指针p将数组元素按要求输出。
inta[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}},*p=a;
{for(j=0;
j++)
%4d”,①);
【3.39】下面程序的功能是:
从键盘上输入一行字符,存入一个字符数组中,然后输出该字符串。
{charstr[81],*sptr:
inti;
80;
{str[i]=getchar():
if(str[i]=='
)break;
str[i]=①:
sptr=str;
while(*sptr)
putchar(*sptr②):
【3.40】下面函数的功能是将字符变量的值插入已经按ASCII码值从小到大排好序的字符串中。
voidfun(char*w,charx,int*n)
{inti,p=0;
while(x>
w[p])①;
for(i=*n:
i>
=p:
i—)②;
w[p]=x;
++*n;
[3.41]下面程序的功能是从键盘上输入两个字符串,对两个字符串分别排序;
然后将它们合并,合并后的字符串按ASCII码值从小到大排序,并删去相同的字符。
strmerge(a,b,c)/*将已排好序的字符串a、b合并到c*/
char*a,*b,*c;
{chart,*w;
w=c;
while(*a!
二'
①*b!
{t=②?
*a++:
*b<
*a?
*b++:
(③);
/*将*8、*b的小者存入t*/
辻(*w④'
)*w=t:
elseif(t⑤*w)*++w=t;
/*将与*闪不相同的t存入w*/
while(*a!
)/*以下将a或b中剩下的字符存入w*/
if(*a!
=*w)*++w=*a++:
elsea++:
while(*b!
辻(*b!
=*w)*++w=*b++;
elseb亠+;
*++*•=⑥;
strsort(char*s)/*将字符串s中的字符排序*/
{inti,j,n;
chart,*w;
for(n=0:
*w!
⑧)
w++;
n-l:
for(j=i+l;
n:
if(s[i]〉s[j])
{⑨}
{charsi[100],s2[100],s3[200];
\nPleas