一、用指针的方法,把输入的一个字符串按逆序重新排序其字符,并输出。 #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<e;b++,e--) {ch=*b; *b=*e; *e=ch; } puts(s); }
二、用指针的方法,将键盘输入的两个字符串连接起来形成一个新字符串。 #include <stdio.h> #include <string.h> 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 <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 <stdio.h> #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 <stdio.h> 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<n;i++) for(j=1;j<m;j++) w[i][0]+=w[i][j]; }
三、己知有若干个学生的数据(包括学号、姓名和一门课程的成绩)。请编程实现:
1. 求课程的平均成绩,输出低于平均成绩的同学的学号、姓名及成绩; 2. 找出学生中的成绩最高者,输出该学生的学号、姓名及成绩; 3. 按成绩从高到低排序并输出。 #include <stdio.h> 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<n;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<n;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<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); } ?
作业十二
一、用指针的方法,把输入的一个字符串按逆序重新排序其字符,并输出。 #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<e;b++,e--) {ch=*b; *b=*e; *e=ch; } puts(s); }
二、用指针的方法,将键盘输入的两个字符串连接起来形成一个新字符串。 #include <stdio.h> #include <string.h> 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 <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 <stdio.h> #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 <stdio.h> 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<n;i++) for(j=1;j<m;j++) w[i][0]+=w[i][j]; }
三、己知有若干个学生的数据(包括学号、姓名和一门课程的成绩)。请编程实现:
1. 求课程的平均成绩,输出低于平均成绩的同学的学号、姓名及成绩; 2. 找出学生中的成绩最高者,输出该学生的学号、姓名及成绩; 3. 按成绩从高到低排序并输出。 #include <stdio.h> 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<n;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<n;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<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); } ?