安阳工学院期末C语言标准标准答案.docx
《安阳工学院期末C语言标准标准答案.docx》由会员分享,可在线阅读,更多相关《安阳工学院期末C语言标准标准答案.docx(41页珍藏版)》请在冰豆网上搜索。
![安阳工学院期末C语言标准标准答案.docx](https://file1.bdocx.com/fileroot1/2023-1/26/a3733dae-135f-4cbd-b795-4ce5617abc7e/a3733dae-135f-4cbd-b795-4ce5617abc7e1.gif)
安阳工学院期末C语言标准标准答案
1
1输入x求y
2abc从大到小排序
3输出四个数中地最大最小值
4输出成绩等级
5输入x输出xy
6输出300-400间地全部素数
7求Fibonacci数列地前二十个数
8求和n!
+3
9求分数数列前20项地和
10水仙花数
11小于六位,逆序输出
12求5+...+55555地和
13求方程地解
14输出一行字符,分别统计出其中地英文字符、数字和其他字符地个数P(25)
24求数组一5个元素和数组二10个元素各元素地平均值
25数组逆序重新存放
26递归法将整数n转换成字符串
27用筛选法求100之内地素数
28编写一个程序,将两个字符串联起来,不要用stract函数
P(5-8)
2
5对10个数用起泡法排序
16二维数组a,b行列互换
173列4行地数组求最大元素及其行列数
18求一行字符地单词数
19求3个字符串地最大者
20输入两个数,求最大者
21求两整数地最大公约数和最小公倍数
22求4个数最大者,嵌套调用
23用递归法求5!
3
29指针输出3个整数从小到大排列
30指针输出3个整数从大到小排列
31指针实现数组b10个元素逆序存放
32冒泡法将10整数从大到小排序
33选择法将10整数从小到大排序
34编写一个函数实现字符串复制功能
35定义结构体变量计算当天是本年地第几天
36设计候选人得票统计程序
37输出学生信息
38输出教师信息
39输出职员信息
40建立动态数组输入5个成绩并检查输出不合格地成绩41求一个字符串地长度
P(9-12)
42一维数组放10个成绩,求平均成绩并输出不及格地
43求10个数中最大,小值,平均值
44找二维数组地鞍点,即元素在该行最大该列最小
458个学生4门课地成绩求三个问题
46将一行字符串最长单词输出
47输出金字塔图案
48输入一个数按原来地规律插入数组中
49判断素数
50统计4行文章60个字符中英文词地信息
51电文密码
52n个人地圈子报数倒3退出,求留下是几号
5310个学生3门课程地成绩,输出总平均成绩,以及最高分地信息54将一字符串地元音字母复制到另一字符串,输出
55输入月份号,输出英文名
P(13-仃)
1■有一个函数,写一段程序,输入x地值,输出y地值.
#includevstdio.h>voidmain()
score
if(bvc)
{t=b;b=c;c=t;}
printf("%7.2f%7.2f%7.2f\n",a,b,c);
}
3.输入4个数,输出4个数中地最大值、最小值.
#includevstdio.h>
voidmain()
{
floatt,a,b,c,d,max,min;
printf("请输入四个数:
");scanf("%f,%f,%f,%f",&a,&b,&c,&d);
if(a
{t=a;a=b;b=t;}
if(a{t=a;a=c;c=t;}
if(a{t=a;a=d;d=t;}
if(b{t=b;b=c;c=t;}
if(bvd)
{t=b;b=d;d=t;}
if(c{t=c;c=d;d=t;}printf("最大值和最小值分别为:
\n");printf("max=%5.2fmin=%5.2f",a,d);
}
4.输入成绩,要求输出成绩等级A、B、C、D、E或
error.90分以上为‘A'80~89分为‘B'70~79分为‘G60~69分为‘D;0~60分为‘E若输入成绩低于0分和高于100分则输出error.
#include
voidmain()
{floatscore;
chargrade;
printf("请输入学生成绩:
");
scanf("%f",&score);
if(score>100||score<0)printf("error\n");
else
{
switch((int)(score/10))
{
case10:
case9:
grade='A';break;
case8:
grade='B';break;
case7:
grade='C';break;
case6:
grade='D';break;
case5:
case4:
case3:
case2:
case1:
case0:
grade='E';
}
printf("成绩是%5.1f,成绩等级是%c.\n",grade);
}
}
for(i=300;iv=400;i++)
5.有一个函数:
{m=prime(i);
写一段程序,输入x地值,输出x,y地值.#includevstdio.h>
voidmain()
{intx,y;
printf("输入x:
");
scanf("%d",&x);
if(x<1)
if(m==1){k++;printf("%5d",i);
if(k%5==0)printf("\n");
}
}
{y=x;printf("x=%3d,y=x=%d\n",x,y);
}
elseif(x<10||x>10)
{y=2*x-1;
printf("x=%d,y=2*x-1=%d\n",x,y);}else
{y=3*x-11;
printf("x=%d,y=3*x-11=%d\n",x,y);
}
}
}
intprime(inti){intj,flag=1;
for(j=2;jv=sqrt(i);j++)if(i%j==0)flag=0;return(flag);
}
2.;#include
#include
voidmain()
6.输出300~400之间地全部素数,并按每行5个数输出.#include
#include
voidmain()
{intprime(int);
inti,k,m;
printf("300-400之间地素数为:
\n");
{intm,k,i,n=0;
for(m=300;mv=400;m=m+1){k=sqrt(m);
for(i=2;iv=k;i++)if(m%i==0)break;
if(i>=k+1){printf("%d",m);
{doubles=0,t=1,sum=0;
intn;
for(n=1;n<=10;n++)
{
t=t*n;
s=s+t;
sum=s+3*n;
}
printf("1!
+3+2!
+3...+10!
+3=%f\n",sum);}
9.有一分数序列,求其前20项地和.
#include
voidmain()
{
inti,n=20;
doublea=2,b=1,s=0,t;
for(i=1;i<=n;i++)
{
s=s+b/a;
t=a,a=a+b,b=t;
}
printf("sum=%16.10f\n",s);
n=n+1;
}
if(n%5==0)printf("\n");
}
printf("\n");
}
7.求Fibonacci数列地前20个数,并将其分5行输出
#include
intmain()
{
intf1=1,f2=1;
inti;
for(i=1;i<=10;i++)
{printf("%12d%12d",f1,f2);if(i%2==0)printf("\n");f1=f1+f2;
f2=f2+f1;
}
return0;
}
8.求和1-10(n!
+3).
#includevoidmain()
}
10.输出小于500地所有地水仙花数”所谓水仙花数
if(nv100000&&n>9999)
printf("它是五位数\n");if(nv10000&&n>999)
printf("它是四位数\n");
if(nv1000&&n>99)
printf("它是三位数\n");
if(nv100&&n>9)
printf("它是二位数\n");
if(nv10&&n>=0)
printf("它是一位数\n");
printf("各位数字按逆序输出为:
\n");while(n!
=0){m=n%10;n=n/10;
printf("%3d",m);
}
}
12.求5+55+555+5555+55555地值.#includevstdio.h>voidmain()
{
inta=5,n=5,i=1,sn=0,tn=0;for(i=1;iv=5;i++)
{
tn=tn+a;
sn=sn+tn;
a=a*10;
}
printf("5+55+..+55555=%d\n",sn);
是指一个3位数,其各位数字立方和等于该数本身.
例如,153是一个水仙花数,因为.
#includevstdio.h>
voidmain()
{
inti,j,k,n;
printf("水仙花数是:
");
for(n=100;nv500;n++)
{
i=n/100;
j=n/10-i*10;
k=n%10;
if(n==i*i*i+j*j*j+k*k*k)
printf("%d",n);
}
printf("\n");
}
11.给一个不多于6位地正整数,要求:
①求出它是几位数
;②分别输出每一位数字;③按逆序输出各位数字,例如原数为158,应输出851
#include
voidmain()
{
intn,m;
printf("输入一个不多于六位地数字:
");
scanf("%d",&n);
if(nv1000000&&n>99999)
printf("它是六位数\n");
}
13求方程地解
#include
#include
intmain()
{doublea,b,c,x1,x2,disc,realpart,imagepart;
scanf("%lf,%lf,%lf",&a,&b,&c);
printf("theequation");
if(fabs(a)<1e-6)
printf("isnotaquadratic");
else
{
disc=b*b-4*a*c;
if(fabs(disc)<1e-6)
printf("hastwoequalroots:
%8.4f\n",-b/(2*a));else
if(disc>1e-6)
{
x1=(-b+sqrt(disc))/(2*a);x2=(-b-sqrt(disc))/(2*a);
printf("hasdiatinctrealroots:
%8.4f,%8.4f\n",x1,x2);b5E2RGbCAP}else
{
}
}
return0;
}
14输入一行字符,分别统计出其中地英文字符、数字和其他字符地个数.
#include
#include
intmain()
{
charc;
intletters=0,digit=0,other=0;
printf("请输入一行字符\n");while((c=getchar())!
='\n');
{
if(c>='a'&&cv='z'||c>='A'&&c<='Z')letters++;
elseif(c>='0'&&c<='9')digit++;
else
other++;
}
printf("字母数:
%d\n数字数:
%d\n其他字符数:
%d\n",letters,digit,other);
return0;
}
15.输入10个整型整数,用起泡法对这10个数排序,
并该由小到大顺序在屏幕上输出.
#include"stdio.h"
realpart=-b/(2*a);imagepart=sqrt(-disc)/(2*a);printf("hascomplexroots:
\n");printf("%8.4f+%8.4fi\n",realpart,imagepart);printf("%8.4f-%8.4fi\n",realpart,imagepart);
voidmain()
{
inta[10];
inti,j,t;
printf("input10number:
\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
for(i=0;i<10;i++)
for(j=i;j<9;j++)if(a[i]>a[j+1]){t=a[i];a[i]=a[j+1];a[j+1]=t;};for(i=0;i<10;i++)printf("%5d",a[i]);
printf("\n");
}
16.将一个二维数组a地行和列地元素互换(即行列互换),存到另一个二维数组b中.
#include"stdio.h"
voidmain()
{
inta[4][5],b[5][4];
inti,j;
for(i=0;i<4;i++)
for(j=0;j<5;j++)scanf("%d",&a[i][j]);
for(i=0;i<5;i++)
for(j=0;j<4;j++)
b[i][j]=a[j][i];
printf("该数组地新序列为:
\n");for(i=0;i<5;i++)
{for(j=0;j<4;j++)printf("%5d",b[i][j]);
printf("\n");
}
}
17.在一个3*4地二维数组a中,要求编程求出其中值最大地那个元素地值,并输出其所在地行号和列号#include"stdio.h"
voidmain()
{
inta[3][4],i,j,max;
for(i=0;i<3;i++)
for(j=0;j<4;j++)scanf("%d",&a[i][j]);
max=a[0][0];
for(i=0;i<3;i++)
for(j=0;j<4;j++)if(maxprintf("行=%2d,列=%2d\n",i+1,j+1);
}
18输入一行字符,统计其中有多少个单词,单词之间用空格分隔开.
#includevstdio.h>
voidmain()
{
inti,j=0;
charstr[80];
gets(str);
for(i=0;str[i]!
='\0';i++)if(str[i+1]==''||str[i+1]=='\0')j++;
printf("单词个数为%d\n",j);
}
19.有3个字符串,要求找出其中最大者.
#include
#include
voidmain()
{
charstr1[80],str2[80],str3[80],longest[80];gets(str1);
printf("\n");
gets(str2);
printf("\n");
gets(str3);
strcpy(longest,str1);if(strcmp(str1,str2)<0)
strcpy(longest,str1);if(strcmp(str2,str3)<0)strcpy(longest,str1);printf("thelongestis%s",longest);
}
20.输入两个整数,要求用一个函数求出其中地大者,并在主函数中输出此值.
#include
voidmain()
{
intf(inta,intb);
intm,n,max;
printf("请输入两个数:
");scanf("%d,%d",&m,&n);max=f(m,n);
printf("max=%d",max);
}
intf(inta,intb)
{
intc;c=a>b?
a:
b;return(c);
}
21输入两个整数,要求用一个函数求出其最大公约数和最小公倍数,并在主函数中调用该子函数.
#include
voidmain()
{inthcf(int,int);
intlcd(int,int,int);
intu,v,h,l;
scanf("%d,%d",&u,&v);
h=hcf(u,v);
printf("最大公约数=%d\n",h);
l=lcd(u,v,h);
printf("最小公倍数=%d\n",l);
}
inthcf(intu,intv)
{intt,r;
if(v>u){t=u;u=v;v=t;}while((r=u%v)!
=0){u=v;v=r;}return(v);
}
intlcd(intu,intv,inth)
{
return(u*v/h);
}
22.输入4个整数,找出其中最大地数.用函数地嵌套调用来处理.
#include
voidmain()
{intmax_4(inta,intb,intc,intd);
inta,b,c,d,max;
printf("Pleaseenter4intergernumbers:
");
scanf("%d%d%d%d",&a,&b,&c,&d);max=max_4(a,b,c,d);printf("max=%d\n",max);
}
intmax_4(inta,intb,intc,intd){intmax_2(inta,intb);
intm;
m=max_2(a,b);
m=max_2(m,c);
m=max_2(m,d);return(m);
}
intmax_2(inta,intb){return(a>b?
a:
b);
}
用递归方法求5!
.
#include
voidmain()
{longfac(intn);
longy;
y=fac(5);
printf("5!
=%ld\n",y);
}
longfac(intn)
{
longf;
if(nv0)printf("n<0,dataerror!
");
elseif(n==0,n==1)
f=1;
else仁fac(n-1)*n;
return(f);
}
24、编写一个函数,用来分别求数组score_1(有5个元
素)和数组score_2(有10个元素)各元素地平均值.
#include
voidmain()
{
floatf(floatscore[],intn);
floatscore_1[5],score_2[10],aver_1,aver_2;
inti;
for(i=0;i<5;i++)
scanf("%f",&score_1[i]);
for(i=0;i<10;i++)
scanf("%f",&score_2[i]);
aver_1=f(score_1,5);
aver_2=f(score_2,10);
printf("aver_1=%f,aver_2=%f\n",aver_1,aver_2);
}
floatf(floatscore[],intn)
{
inti;
floataver,sum=0;
for(i=0;iaver=sum/n;
return(aver);
}
25将一个数组中地值按逆序重新存放■例如,原来顺序为8,6,5,4,1改后成为1,4,5,6,8.
#include
voidmain()
{
inta[6],b[6],i;
printf("请输入一个数组:
");for(i=0;i<6;i++)scanf("%d",&a[i]);
printf("逆序排列后地数组是:
");for(i=0;i<6;i++)
{b[i]=a[5-i];printf("%4d",b[i]);
}
}
26用递归法将一个整数n转换成字符串■例如,输入483,应输出字符串“483”n地位数不确定,可以是任意位数地整数.
#include
voidmain()
{voidconvert(intn);
intnumber;
printf("inputaninteger:
");scanf("%d",&number);printf("output:
");
if(numbervO){putchar('-');putchar('');number=-number;
}
convert(number);printf("\n");
}
voidconvert(intn)
{inti;
if((i=n/10)!
=0)convert(i);
putchar(n%10+'0');putchar(32);
}
27用筛选法求100之内地素数
#include#includeintmain(){inti,j,a[1O1];
for(i=1;i<100;i++)
a[i]=i;a[1]=0;for(i=2;ifor(j=i+1;jv=100;j++)
{if(a[i]!
=0&&a[j]!
=0)if(a[j]%a[i]==0)a[j]=0;
}printf("\n");
for(i=2;i<100;i++){if(a[i]!
=0)printf("%5d",a[i]);
}printf("\n");return0;
}
28编写一个程序,将两个字符串联起来,不要用stract函数
#include
intmain()
{chars1[80],s2[40];
inti=0,j=0;
printf("inputstringl:
");scanf("%s",s1);
printf("inputstring2:
");scanf("%s",s2);
while(s1[i]!
='\0')
i++;
while(s2[j]!
='\0')s1[i++]=s2[j++];s1[i]='\0';
print