c语言程序填空题1.docx

上传人:b****4 文档编号:26812348 上传时间:2023-06-22 格式:DOCX 页数:34 大小:28.40KB
下载 相关 举报
c语言程序填空题1.docx_第1页
第1页 / 共34页
c语言程序填空题1.docx_第2页
第2页 / 共34页
c语言程序填空题1.docx_第3页
第3页 / 共34页
c语言程序填空题1.docx_第4页
第4页 / 共34页
c语言程序填空题1.docx_第5页
第5页 / 共34页
点击查看更多>>
下载资源
资源描述

c语言程序填空题1.docx

《c语言程序填空题1.docx》由会员分享,可在线阅读,更多相关《c语言程序填空题1.docx(34页珍藏版)》请在冰豆网上搜索。

c语言程序填空题1.docx

c语言程序填空题1

三、程序填空题

导读:

在程序填空题中,已经给出了程序的主干,读者首先要理解程序的思路,再选择正确的内容填入空白处,使程序完成既定的功能。

这类习题的设计就是要引导读者逐步掌握编程的方法。

本节习题的难度适中,可能有些典型的程序在课堂上已经有所接触,读者一定要独立完成它,这样就可以逐步提高自己的编程能力。

在程序设计语言学习的中期,读者对程序设计已经有了初步的了解,而自己编写程序又不知从何处入手,此时解答此类题目可以避免盲目性,从而提高学习的效率。

【3.1】下面程序的功能是不用第三个变量,实现两个数的对调操作。

#include

main()

{inta,b;

scanf("%d%d",&a,&b);

printf("a=%d,b=%d\n",a,b);

a=①;

b=②;

a=③;

printf("a=%d,b=%d\n",a,b);

}

【3.2】下面程序的功能是根据近似公式:

π2/6≈1/12+1/22+1/32+……+1/n2,求π值。

#include

doublepi(longn)

{doubles=0.0;

longi;

for(i=1;i<=n;i++)

s=s+①;

return(②);

}

【3.3】下面的程序的功能是求一维数组中的最小元素。

findmin(int*s,intt,int*k)

{intp;

for(p=0,*k=p;p

if(s[p]

①;

}

main()

{inta[10],i,*k=&i;

for(i=0;i<10;i++)

scanf("%d",&a[i]);

findmin(a,10,k);

printf("%d,%d\n",*k,a[*k]);

}

【3.4】下面程序的功能是计算1-3+5-7+……-99+101的值。

main()

{inti,t=1,s=0;

for(i=1;i<=101;i+=2)

{①;

s=s+t;

②;

}

printf("%d\n",s);

}

【3.5】有以下程序段:

s=1.0;

for(k=1;k<=n;k++)

s=s+1.0/(k*(k+1));

printf("%f\n",s);

填空完成下述程序,使之与上述程序的功能完全相同。

s=0.0;

①;

k=0;

do

{s=s+d;

②;

d=1.0/(k*(k+1));

}while(③);

printf("%f\n",s);

【3.6】下面程序的功能是从键盘上输入若干学生的学习成绩,统计并输出最高成绩和最低成绩,当输入为负数时结束输入。

main()

{floatx,amax,amin;

scanf("%f",&x);

amax=x;

amin=x;

while(①)

{if(x>amax)amax=x;

if(②)amin=x;

scanf("%f",&x);

}

printf("\namax=%f\namin=%f\n",amax,amin);

}

【3.7】下面程序的功能是将形参x的值转换为二进制数,所得的二进制数放在一个一维数组中返回,二进制数的最低位放在下标为0的元素中。

fun(intx,intb[])

{intk=0,r;

do

{r=x%①;

b[k++]=r;

x/=②;

}while(x);

}

【3.8】下面程序的功能是输出1到100之间每位数的乘积大于每位数的和的数。

例如数字26,数位上数字的乘积12大于数字之和8。

main()

{intn,k=1,s=0,m;

for(n=1;n<=100;n++)

{k=1;

s=0;

①;

while(②)

{k*=m%10;

s+=m%10;

③;

}

if(k>s)

printf("%d",n);

}

}

【3.9】下面程序的功能是统计用0至9之间的不同的数字组成的三位数的个数。

main()

{inti,j,k,count=0;

for(i=1;i<=9;i++)

for(j=0;j<=9;j++)

if(①)continue;

elsefor(k=0;k<=9;k++)

if(②)count++;

printf("%d",count);

}

【3.10】下面程序的功能是输出100以内的个位数为6、且能被3整除的所有数。

main()

{inti,j;

for(i=0;①;i++)

{j=i*10+6;

if(②)countinue;

printf("%d",j);

}

}

【3.11】下面程序的功能是用辗转相除法求两个正整数m和n的最大公约数。

hcf(intm,intn)

{intr;

if(m

{r=m;

①;

n=r;

}

r=m%n;

while(②)

{m=n;

n=r;

r=m%n;

}

③;

}

【3.12】下面程序的功能是使用冒泡法对输入的10个浮点数从小到大进行排序。

排好序的10个数分两行输出。

程序如下:

#include

main()

{①;

inti,j;

printf("Input10numbersplease\n");

for(i=0;②;i++)

scanf("%f",&a[i]);

printf("\n");

for(i=2;③;i++)

for(j=0;④;j++)

if(⑤)

{x=a[j];

⑥;

a[j+1]=x;

}

printf("Thesorted10numbers;\n");

for(i=0;⑦;i++)

{if(⑧)

printf("\n");

printf("%f\t",a[i]);

}

printf("\n");

}

【3.13】下面程序的功能是读入20个整数,统计非负数个数,并计算非负数之和。

#include"stdio.h"

main()

{inti,a[20],s,count;

s=count=0;

for(i=0;i<20;i++)

scanf("%d",①);

for(i=0;i<20;i++)

{if(a[i]<0)

②;

s+=a[i];

count++;

}

printf("s=%d\tcount=%d\n",s,count);

}

【3.14】下面程序的功能是删除字符串s中的空格。

#include

main()

{char*s="Beijingligongdaxue";

inti,j;

for(i=j=0;s[i]!

='\0';i++)

if(s[i]!

='')①;

else②;

s[j]='\0';

printf("%s",s);

}

【3.15】下面程序的功能是将字符串s中所有的字符'c'删除。

请选择填空。

#include

main()

{chars[80];

inti,j;

gets(s);

for(i=j=0;s[i]!

='\0';i++)

if(s[i]!

='c')①;

s[j]='\0';

puts(s);

}

【3.16】下面程序的功能是输出两个字符串中对应相等的字符。

请选择填空。

#include

charx[]="programming";

chary[]="Fortran";

main()

{inti=0;

while(x[i]!

='\0'&&y[i]!

='\0')

if(x[i]==y[i])

printf("%c",①);

else

i++;

}

【3.17】下面程序的功能是将字符串s中的每个字符按升序的规则插到数组a中,字符串a已排好序。

#include

main()

{chara[20]="cehiknqtw";

chars[]="fbla";

inti,k,j;

for(k=0;s[k]!

='\0';k++)

{j=0;

while(s[k]>=a[j]&&a[j]!

='\0')

j++;

for(①)

②;

a[j]=s[k];

}

puts(a);

}

【3.18】下面程序的功能是对键盘输入的两个字符串进行比较,然后输出两个字符串中第一个不相同字符的ASCII码之差。

例如:

输入的两个字符串分别为"abcdefg"和"abceef",则输出为-1。

#include

main()

{charstr1[100],str2[100],c;

inti,s;

printf("Enterstring1:

");gets(str1);

printf("Enterstring2:

");gets(str2);

i=0;

while((str1[i]==str2[i]&&str1[i]!

=①))

i++;

s=②;

printf("%d\n",s);

}

【3.19】下面的函数expand在将字符串s复制到字符串t时,将其中的换行符和制表符转换为可见的转义字符表示,即用'\n'表示换行符,用'\t'表示制表符。

expand(chars[],chart[])

{inti,j;

for(i=j=0;s[i]!

='\0';i++)

switch(s[i])

{case'\n':

t[①]=②;

t[j++]='n';

break;

case'\t':

t[③]=④;

t[j++]='t';

break;

default:

t[⑤]=s[i];

break;

}

t[j]=⑥;

}

【3.20】下面的函数index(chars[],chart[])检查字符串s中是否包含字符串t,若包含,则返回t在s中的开始位置(下标值),否则送回-1。

index(chars[],chart[])

{inti,j,k;

for(i=0;s[i]!

='\0';i++)

{for(j=i,k=0;①&&s[j]==t[k];j++,k++);

if(②)

return(i);

}

return(-1);

}

n

【3.21】下面程序的功能是计算S=k!

k=0

longfun(intn)

{inti;

longs;

for(i=1;i①;i++)

s*=i;

return(②);

}

main()

{intk,n;

longs;

scanf("%d",&n);

s=③;

for(k=0;k<=n;k++)

s+=④;

printf("%ld\n",s);

}

【3.22】下面程序的功能是显示具有n个元素的数组s中的最大元素。

#defineN20

main()

{inti,a[N];

for(i=0;i

scanf("%d",&a[i]);

printf("%d\n",①);

}

fmax(ints[],intn)

{intk,p;

for(p=0,k=p;p

if(s[p]>s[k])②;

return(k);

}

【3.23】下面程序的功能是由键盘输入n,求满足下述条件的x、y:

nx和ny的末3位数字相同,且x≠y,x、y、n均为自然数,并使x+y为最小。

#include

pow3(intn,intx)

{inti,last;

for(last=1,i=1;i<=x;i++)

last=①;

return(last);

}

main()

{intx,n,min,flag=1;

scanf("%d",&n);

for(min=2;flag;min++)

for(x=1;x

if(②&&pow3(n,x)==pow3(n,min-x))

{printf("x=%d,y=%d\n",x,min-x);

③;

}

}

【3.24】下面的程序是用递归算法求a的平方根。

求平方根的迭代公式如下:

#include

doublemysqrt(doublea,doublex0)

{doublex1,y;

x1=①;

if(fabs(x1-x0)>0.00001)

y=mysqrt(②);

elsey=x1;

return(y);

}

main()

{doublex;

printf("Enterx:

");

scanf("%lf",&x);

printf("Thesqrtof%lf=%lf\n",x,mysqrt(x,1.0));

}

【3.25】以下程序是计算学生的年龄。

已知第一位最小的学生年龄为10岁,其余学生的年龄一个比一个大2岁,求第5个学生的年龄。

#include

age(intn)

{intc;

if(n==1)c=10;

elsec=①;

return(c);

}

main()

{intn=5;

printf("age:

%d\n",②);

}

【3.26】下面的函数sum(intn)完成计算1~n的累加和。

  sum(intn)

{if(n<=0)

printf("dataerror\n");

if(n==1)①;

else②;

}

【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(1,n)=n为止。

当n<2*m时,可先用公式

(1)进行简化,填写程序中的空白,使程序可以正确运行。

#include"stdio.h"

main()

{intm,n;

printf("Inputm,n=");

scanf("%d%d",&m,&n);

printf("Thecombinationnumbeersis%d\n",combin(m,n));

}

combin(intm,intn)

{intcom;

if(n<2*m)m=n-m;

if(m==0)com=1;

elseif(m==1)①;

else②;

return(com);

}

【3.29】下列函数是求一个字符串str的长度。

intstrlen(char*str)

{if(①)return(0);

elsereturn(②);

}

【3.30】用递归实现将输入小于32768的整数按逆序输出。

如输入12345,则输出54321。

#include"stdio.h"

main()

{intn;

printf("Inputn:

");

scanf("%d",①);

r(n);

printf("\n");

}

r(intm)

{printf("%d",②);

m=③;

if(④)

⑤;

}

【3.31】输入n值,输出高度为n的等边三角形。

例如当n=4时的图形如下:

*

***

*****

*******

#include

voidprt(charc,intn)

{if(n>0)

{printf("%c",c);

①;

}

}

main()

{inti,n;

scanf("%d",&n);

for(i=1;i<=n;i++)

{②;

③;

printf("\n");

}

}

【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++;

①;

if(s

{c=*s;

*s=*p;

②;

revstr(s+1);

③;

}

}

  如下是由非递归实现的revstr(s)函数:

revstr(s)

char*s;

{char*p=s,c;

while(*p)p++;

④;

while(s

{c=*s;

⑤=*p;

*p--=c;

}

}

【3.34】下面函数用递归调用的方法,将str中存放的长度为n的字符串反转过来,例如原来是"ABCDE",反序为"EDCBA"。

voidinvent(char*str,intn)

{chart;

t=*str;*str=*(str+n-1);*(str+n-1)=t;if(n>2)invent(①,n-2);

else②;

}

【3.35】从键盘上输入10个整数,程序按降序完成从大到小的排序。

#include

intarray[10];

sort(int*p,int*q)

{int*max,*s;

if(①)

return;

max=p;for(s=p+1;s<=q;s++)

if(*s>*max)

②;swap(③);

sort(④);}

swap(int*x,int*y){inttemp;

temp=*x;

*x=*y;

*y=temp;

}

main()

{inti;printf("Enterdata:

\n");for(i=0;i<10;i++)

scanf("%d",&array[i]);sort(⑤);

printf("Output:

");

for(i=0;i<10;i++)

printf("%d",array[i]);

}

【3.36】下面函数的功能是将一个整数存放到一个数组中。

存放时按逆序存放。

例如:

483存放成"384"。

#include

voidconvert(char*a,intn)

{inti;

if((i=n/10)!

=0)

convert(①,i);

*a=②;

}

charstr[10]="";

main()

{intnumber;

scanf("%d",&number);

convert(str,number);

puts(str);

}

【3.37】下面程序的功能是实现数组元素中值的逆转。

#include

main()

{inti,n=10,a[10]={1,2,3,4,5,6,7,8,9,10};

invert(a,n-1);

for(i=0;i<10;i++)

printf("%4d",a[i]);

printf("\n");

}

invert(int*s,intnum)

{int*t,k;

t=s+num;

while(①)

{k=*s;

*s=*t;

*t=k;

②;

③;

}

}

【3.38】下面程序通过指向整型的指针将数组a[3][4]的内容按3行×4列的格式输出,请给printf()填入适当的参数,使之通过指针p将数组元素按要求输出。

#include

inta[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}},*p=a;

main()

{inti,j;

for(i=0;i<3;i++)

{for(j=0;j<4;j++)

printf("%4d",①);

}

}

【3.39】下面程序的功能是:

从键盘上输入一行字符,存入一个字符数组中,然后输出该字符串。

#include

main()

{charstr[81],*sptr;

inti;

for(i=0;i<80;i++)

{str[i]=getchar();

if(str[i]=='\n')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码值从小到大排序,并删去相同的字符。

#include

strmerge(a,b,c)/*将已排好序的字符串a、b合并到c*/

char*a,*b,*c;

{chart,*w;

w=c;

while(*a!

='\0'①*b!

='\0')

{t=②?

*a++:

*b<*a?

*b++:

(③);/*将*a、*b的小者存入t*/

if(*w④'\0')*w=t;

elseif(t⑤*w)*++w=t;/*将与*w不相同的t存入w*/

}

while(*a!

='\0')/*以下将a或b中剩下的字符存入w*/

if(*a!

=*w)*++w=*a++;

elsea++;

while(*b!

='\0')

if(*b!

=*w)*++w=*b++;

elseb++;

*++w=⑥;

}

strsort(char*s)/*将

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高中教育 > 其它课程

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1