搜档网
当前位置:搜档网 › C语言经典例题及答案

C语言经典例题及答案

一、求一个任意边长的矩形面积。

#include

void main()

{int w,h,sum;

scanf("%d%d",&w,&h);

sum=w*h;

printf("area=%d\n",sum);

}

二、求一个任意半径的圆的面积及周长。

#define PI 3.14159

#include

void main()

{float r,area,c;

scanf("%f",&r);

area=PI*r*r;

c=2*PI*r;

printf("area=%f\ncircle=%f\n",area,c);

}

三、已知:w=5, y=4, z=2, 求表达式:w*y/z的值,并输出。

##include

void main()

{ int w,y,z,r;

w=5;

y=4;

z=2;

r=w*y/z;

printf("%5d",r);

}

一、从键盘上输入三个数,求出其中的最大值,并输出。

#include

void main()

{int a,b,c,max;

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

max=a;

if(max

if(max

printf("max=%d\n",max);

}

二、求sin300。+sin600+cos300+cos600之和。(注意:30*3.14159/180)

#include

#define PI 3.14159

#include

void main()

{float a,b,sum;

a=30*PI/180;

b=60*PI/180;

sum=sin(a)+sin(b)+cos(a)+cos(60);

printf("total=%f\n",sum);

}

三、比较两个数的大小。如果x大于y,则输出:x>y,否则输出:x

void main()

{int x,y;

scanf("%d,%d",&x,&y);

if(x>y)

printf("x>y\n");

else

printf("x

}

一、输入a、b、c三个值,按从小到大排序输出。

#include

void main()

{int a,b,c,t;

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

if(a>b)

{ t=b;

b=a;

a=t;

}

if(a>c)

{t=a;

a=c;

c=t;

}

if(b>c)

{t=b;b=c;c=t;}

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

}.

二、求自然数1~10之和。。

#include

void main()

{int i,sum;

i=1;

sum=0;

while(i<=10)

{

sum=sum+i;

i++;

}

printf("sum=%d\n",sum);

}

三、输入10个整数,统计出正数之和以及负数之和。(求奇数之和以及偶数之和)#include

void main()

{int sum1=0,sum2=0,i,x;

i=1;

while(i<=10)

{ scanf("%d",&x);

if(x%2==0)

sum1=sum1+x;

else

sum2=sum2+x;

i++;

}

printf("sum1=%d\nsum2=%d\n",sum1,sum2);

}

一、输入一个0~6的整数,转换成星期输出。

#include

main()

{ int a;

scanf("%d",&a);

switch(a)

{

case 0: printf("Sunday");break;

case 1: printf("Monday");break;

case 2: printf("Tuesday");break;

case 3: printf("Wednesday");break;

case 4: printf("Thursday");break;

case 5: printf("Friday");break;

case 6: printf("saturday");break;

default: printf("I am sorry.You are wrong.\n");

}

}.

二、输入一个整数,将各位数字反转后输出。如:输入365,则输出显示为563。#include

void main()

{int x,r;

scanf("%d",&x);

printf("conver is:");

while(x!=0)

{ r=x%10;

printf("%d",r);

x=x/10;

}

printf("\n");

}

三、输入一个整数,求出它的所有因子。

#include

void main()

{

int x,i;

scanf("%d",&x);

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

if(x%i==0)

printf("%3d",i);

}

一、求100 ~200之间的素数。

#include

#include

void main()

{int j=0,x,n,i;

for(x=100;x<=200;x++)

{

n=sqrt(x);

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

{ if(x%i==0)break;

}

if(i>n)

{

printf("%5d",x);

j++;

}

if(j%5==0)printf("\n");

}

}

二、编程输出三角形的9×9乘法表。

#include

void main()

{

int i,j;

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

{

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

printf("%d*%d=%d ",i,j,i*j);

printf("\n");

}

}

三、求任意二个数的最大公约数。

#include

main()

{ int a,b,m,n,q;

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

a=m; b=n;

if(a>b)

{ int z;

z=a;

a=b;

b=z;

}

do{ q=b%a;

b=a;a=q;

}while(q!=0);

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

}

一、利用循环语句求 1

217151311-++-+-

n ΛΛ(直到第100项的和)。 #include

void main()

{ int i,t=1;

float s=1,p=0,n=1;

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

{ p=p+s;

n=n+2;

t=-t;

s=t/n;

}printf("%f\n",p);

}

二、编写求 S=∑=5

1n n !

。 #include

void main()

{ int x,y=0,n,i;

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

{ x=1;

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

x=x*i;

y=y+x;

}

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

}

三、利用公式求 cosx 的近似值(精度为10-6):

)!2()1(!6!4!21cos 20

6

42n x x x x x n n n ∑∞=-=-+-=Λ #include

#include

void main()

{ float n=1,t=1,pi=0,s=1,x,i=1;

scanf("%f",&x);

while(fabs(t)>=1e-6)

{ pi+=t;

n=n*i*(i+1);

s=-s*x*x;

i++;

t=s/n;

}

printf("%f",pi);

}

一、用选择法对10个整数排序(由大到小)。

#include

void main(void)

{ int a[10],i,j,t;

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

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

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

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

if(a[j]>a[j+1])

{ t=a[j];

a[j]=a[j+1];

a[j+1]=t;

}

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

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

printf("\n");

}

二、输入10个学生的一门课成绩,用一维数组存放其成绩,统计并输出不及格人数及其百

分比。

#include

void main(void)

{ int i,count=0;

float score[10],percent;

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

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

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

if(score[i]<60)

count++;

percent=(float)count/10;

printf("%d,%5.1f",count,percent);

}

三、编程实现N阶方阵转置。

#include

void main()

{ int a[3][3],b[3][3],i,j;

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

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

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

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

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

b[j][i]=a[i][j];

printf("\n");

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

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

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

printf("\n");

}

}

一、把输入的一个字符串按逆序重新排序其字符,并输出。

#include

#include

void main()

{ char a[80],k;

int i,j;

gets(a);

for(i=0,j=strlen(a)-1;i

{ k=a[i];

a[i]=a[j];

a[j]=k;

}

puts(a);

}

二、从键盘输入一个字符串。要求分别统计出其中英文大写字母、小写字母、数字、空格、

以及其它字符的个数

#include

void main()

{ int i,a=0,b=0,c=0,d=0,e=0;

char q[20];

gets(q);

for(i=0;q[i]!='\0';i++)

{

if(q[i]>='0'&&q[i]<='9')

a++ ;

else if(q[i]>='a'&&q[i]<='z')

b++;

else if(q[i]>='A'&&q[i]<='Z')

c++;

else if(q[i]==' ')

d++;

else e++;

}

printf("%3d%4d%3d%3d%3d",a,b,c,d,e);

}

三、输入五个英文单词,请找出它们之中按字典排序法排在最前的一个词。

#include

#include

void main()

{ char a[5][30],b[30];

int i,j,k;

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

gets(a[i]);

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

{ k=i;strcpy(b,a[i]);

for(j=i+1;j<5;j++)

if(strcmp(a[j],b)<0)

{ k=j;

strcpy(b,a[j]);

}

if(k!=i)

{ strcpy(b,a[i]);

strcpy(a[i],a[k]);

strcpy(a[k],b);

}

puts(a[i]);

}

printf("\n");

}

一、编写一函数,将字符串中的小写字母转换为大写字母,主函数输入字符串并输出结果。

#include

char change (char a[])

{ int i;

for(i=0;a[i]!='\0';i++)

if(a[i]>='a'&&a[i]<='z')

a[i]=a[i]-32;

}

void main()

{ char b[80];

gets(b);

change(b);

puts(b);

}

二、编写一函数求N!。在主函数中输入N,调用函数求N!,输出结果。

#include

int sum(int n)

{ int i,pi=1;

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

pi=pi*i;

return(pi);

}

void main()

{ int p=0,n;

scanf("%d",&n);

p=sum(n);

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

}

三、编写一个函数,求二维数组所有元素的和,要求二维数组的行、列以及数组通过函数参数传递,并通过主函数调用求2行3列的数组的所有元素之和。

#include

int num(int a[2][3], int n,int m)

{ int sum=0,i,j;

for(i=0;i

for(j=0;j

sum=sum+a[i][j];

return(sum);

}

void main()

{ int a[2][3],i,j;

int p=0,n=2,m=3;

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

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

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

p=num(a,n,m);

printf("%d",p);

}

一、编写程序,通过函数求6 –300以内的素数的和。

#include

#include

void main( )

{int i,sum=0;

int per(int);

for(i=6;i<=300;i++)

sum=sum+per(i);

printf("SUM=%d\n",sum);

}

int per(int n)

{ int k,i;

k=sqrt(n);

for(i=2;i<=k;i++)

if(n%i==0)break;

if(i>=k+1)

return n;

else

return 0;

}

/* 8265*/

二、求sin300。+sin600+cos300+cos600之和。(自编sin和cos函数) #include

#include

#define PI 3.14159

void main( )

{ float y,x30,x60;

float sin1(float);

float cos1(float);

x30=30*PI/180;

x60=60*PI/180;

y=sin1(x30)+cos1(x30)+sin1(x60)+cos1(x60);

printf("SUM=%f\n",y);

}

float sin1( float x)

{ float sum=0,t=x;

int i=1,f=1;

do{

sum=sum+t;

i=i+2;

f=-f;

t=t*f*x*x/(i*(i-1));

}while(fabs(t)

>1e-6);

return sum;

}

float cos1(float x)

{ float sum=0,t=1;

int i=0,f=1;

do{

sum=sum+t;

i=i+2;

f=-f;

t=t*f*x*x/(i*(i-1));

}while(fabs(t)>1e-6);

return sum;

}

/*SUM=2.608201*/

三 、编写函数,求级数S=1+2+3+...n ,并在主函数中求:

)

7654321()654321()54321()4321()321(+++++++++++++++++++++++=y #include

int f(int);

void main( )

{ float s;

s=(float)(f(3)+f(4)+f(5))/(f(5)+f(6)+f(7));

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

}

int f(int a)

{int sum=0,i;

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

sum=sum+i;

return sum;

}

/* SUM=0.484375*/

一、编写一个函数,求一维数组的平均值、最大值。

#include

void main( )

{int a[5],i,max;

void maxave(int w[5],int *p,float *q);

float ave=0;

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

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

maxave(a,&max,&ave);

printf("MAX=%d,A VER=%f\n",max,ave);

}

void maxave(int w[5],int *p,float *q)

{int i;

*p=w[0];

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

if(*p

*p=w[i];

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

*q=*q+w[i];

*q=*q/5;

}

二、输入10个数,编写一个函数,按降序对其排序,统计其中大于平均值的数的个数。 #include

int sort(int w[],int n);

void main( )

{ int i,a[10],count=0;

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

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

count=sort(a,10);

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

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

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

}

int sort(int w[],int n)

{ int i,j,t,c=0;

float av=0;

for(i=0;i

for(j=i+1;j

if(w[i]

{t=w[i];

w[i]=w[j];

w[j]=t;

}

for(i=0;i

av=av+w[i];

av/=10;

for(i=0;i

if(w[i]>av)

c++;

return c;

}

三、编写一个函数,求N阶二维矩阵的主和辅对角线元素之和。#include

#define N 3

void main( )

{ int a[N][N],i,j,sum,sun;

for(i=0;i

for(j=0;j

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

for(i=0;i

{for(j=0;j

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

printf("\n");

}

sum=zdj(a,N);

sun=fdj(a,N);

printf("sum=%d,sun=%d\n",sum,sun);

}

int zdj(int c[][N],int n)

{int i,s=0;

for(i=0;i

s+=c[i][i];

return s;

}

int fdj(int d[][N],int n)

{int i,j,s=0;

for(i=0;i

for(j=0;j

if(i+j==n-1)

s+=d[i][j];

return s;

}

一、用指针的方法,把输入的一个字符串按逆序重新排序其字符,并输出。#include

#include

void main( )

{ char w[20],ch,*b,*e,*s;

int i;

s=b=w;

gets(w);

i=strlen(w);

e=s+i-1;

for(;b

{ch=*b;

*b=*e;

*e=ch;

}

puts(s);

}

二、用指针的方法,将键盘输入的两个字符串连接起来形成一个新字符串。#include

#include

void main( )

{char a[30],b[20],*p,*q,*s;

int i,j;

p=s=a;

q=b;

gets(p);

gets(q);

i=strlen(p);

p=p+i;

while(*p++=*q++)

;

puts(s);

}

三、用指针的方法,将键盘上输入的一串数值字符串转换为数值输出。如输入:‘-132’,则

输出为:-132。

#include

#include

void main( )

{char a[10],*p;

int t=1,n=0;

gets(a);

p=a;

if(*p=='-')

{t=-t;

p++;

}

while(*p!='\0')

{n=n*10+(*p-'0');

p++;

}

n=n*t;

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

}

一、通过函数统计某字符串中,英文单词的个数。(参考p69)

#include

#define YES 1

#define NO 0

void main()

{

int nl,nw,nc,inword;

char c;

inword=NO;

nl=nw=nc=0;

while((c=getchar())!='*')

{

++nc;

if(c=='\n')

++nl;

if(c==' ' || c=='\t' || c=='\n')

inword=NO;

else

if(inword==NO)

{inword=YES;

++nw;

}

}

nl++;

nc++;

printf("%d\t%d\t%d\n",nl,nw,nc);

}

二、在主函数中初始化一个3行4列的矩阵并将每个元素都输出,然后调用子函数,分别计

算每一行的元素之和,将和直接存放在每行的第一个元素中,返回主函数之后输出各行元素的和。

#include

void main()

{int a[3][4],i,j;

void sum(int w[][4],int n,int m);

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

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

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

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

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

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

printf("\n");

}

sum(a,3,4);

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

{printf("%3d",a[i][0]);

printf("\n");

}

}

void sum(int w[][4],int n,int m)

{int i,j;

for(i=0;i

for(j=1;j

w[i][0]+=w[i][j];

}

三、己知有若干个学生的数据(包括学号、姓名和一门课程的成绩)。请编程实现:

1.求课程的平均成绩,输出低于平均成绩的同学的学号、姓名及成绩;

2.找出学生中的成绩最高者,输出该学生的学号、姓名及成绩;

3.按成绩从高到低排序并输出。

#include

struct student{

int num;

char name[8];

float score;

};

float average(struct student w[],int n)

{float av=0;

int i;

for(i=0;i

av=av+w[i].score;

av=av/n;

return av;

}

int mmax(struct student w[],int n)

{int i, maxi=0;

float max=w[0].score;

for(i=0;i

if(w[i].score>max)

{max=w[i].score;

maxi=i;

}

return maxi;

}

void sort(struct student w[],int n)

{int i,j,k;

struct student t;

for(i=0;i

{ k=i;

for(j=i+1;j

if(w[k].score

if(k!=i)

{t=w[i];

w[i]=w[k];

w[k]=t;

}

}

}

void main()

{struct student stu[5]={{11,"aa",80},{22,"bb",90},{33,"cc",70},{44,"dd",80},{55,"ee", 60}};

int i,maxi;

float av;

av=average(stu,5);

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

if(stu[i].score

printf("%d %s %f\n",stu[i].num,stu[i].name,stu[i].score);

maxi=mmax(stu,5);

printf("%d %s %f\n",stu[maxi].num,stu[maxi].name,stu[maxi].score);

sort(stu,5);

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

printf("%d %s %f\n",stu[i].num,stu[i].name,stu[i].score);

}

相关主题