当前位置:文档之家› C语言经典例题和答案

C语言经典例题和答案

C语言经典例题和答案
C语言经典例题和答案

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

#include <stdio。h〉

void main()

{int w,h,sum;

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

sum=w*h;

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

}

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

#definePI 3、14159

#include <stdio。h>

void main()

{floatr,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〈stdio.h>

void main()

{ int w,y,z,r;

w=5;

y=4;

z=2;

r=w*y/z;

printf(”%5d”,r);

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

#include 〈stdio、h>

void main()

{int a,b,c,max;

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

max=a;

if(max

if(max<c) max=c;

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

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

#define PI 3.14159

#include <math。h>

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〈y。#include<stdio。h>

void main()

{int x,y;

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

if(x〉y)

printf("x〉y\n”);

else

printf(”x〈y\n”);

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

#include 〈stdio。h〉

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 〈stdio.h>

void main()

{int i,sum;

i=1;

sum=0;

while(i〈=10)

sum=sum+i;

i++;

}

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

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

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 〈stdio。h>

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 <stdio。h〉

#include〈math、h>

voidmain()

{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

voidmain()

{

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);

}?

一、利用循环语句求 (直到第100项得与)。

#include 〈stdio.h>

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=、

#include〈stdio、h>

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):

#include

#include <math、h>

void main()

{ floatn=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〈stdio.h〉

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 〈stdio。h>

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 <stdio、h〉

#include <string。h>

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 <stdio。h>

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

elseif(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 <string。h〉

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 〈stdio.h〉

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〈stdio。h>

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

{ int sum=0,i,j;

for(i=0;i〈n;i++)

for(j=0;j〈m;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<stdio.h〉

#include

void main( )

{inti,sum=0;

int per(int);

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

sum=sum+per(i);

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

int per(intn)

{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 <stdio.h〉

#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,并在主函数中求:

#include 〈stdio。h>

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)

{intsum=0,i;

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

sum=sum+i;

return sum;

}

/*SUM=0。484375*/

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

#include〈stdio。h〉

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,AVER=%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〈w[i])

*p=w[i];

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

*q=*q+w[i];

*q=*q/5;

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

int sort(intw[],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〈n;j++)

if(w[i]

{t=w[i];

w[i]=w[j];

w[j]=t;

?}

for(i=0;i〈n;i++)

av=av+w[i];

av/=10;

for(i=0;i〈n;i++)

if(w[i]>av)

c++;

returnc;

三、编写一个函数,求N阶二维矩阵得主与辅对角线元素之与、

#include

#define N 3

void main( )

{ inta[N][N],i,j,sum,sun;

for(i=0;i〈N;i++)

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

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

for(i=0;i〈N;i++)

{for(j=0;j〈N;j++)

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

printf(”\n”);

sum=zdj(a,N);

sun=fdj(a,N);

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

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

{int i,s=0;

for(i=0;i<n;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<n;j++)

if(i+j==n—1)

s+=d[i][j];

return s;

}

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

#include〈string、h>

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〈stdio、h>

#include <string.h>

voidmain( )

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

inti,j;

p=s=a;

q=b;

gets(p);

gets(q);

i=strlen(p);

p=p+i;

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

;

puts(s);

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

输出为:—132、

#include 〈stdio。h〉

#include<string、h>

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");

}

}

voidsum(int w[][4],int n,int m)

{int i,j;

for(i=0;i<n;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 studentw[],int n)

{int i, maxi=0;

float max=w[0]、score;

for(i=0;i〈n;i++)

if(w[i].score>max)

{max=w[i].score;

maxi=i;

}

return maxi;

void sort(struct student w[],intn)

{inti,j,k;

struct student t;

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

{ k=i;

for(j=i+1;j〈n;j++)

if(w[k]、score〈w[j]、score)k=j;

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〈av)

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);

}

?

相关主题
文本预览
相关文档 最新文档