一、通过函数统计某字符串中,英文单词的个数。(参考p69)
#include <stdio.h>
#define YES 1
#define NO 0
void main()
{
intnl,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;
voidsum(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{
intnum;
char name[8];
float score;
};
float average(struct student w[],int n)
{float av=0;
inti;
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 studentstu[5]={{11,"aa",80},{22,"bb",90},{33,"cc",70},{44,"dd",80},{55,"ee",
60}};
inti,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);
}