一、求一个任意边长得矩形面积。
#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); } ?