struct book
{
char name[30];//图书名称
float price;//价格
int year;//借阅时间
int moth;
int day;
char id[20];//流水号
char user[10];//借阅人姓名
int userid;//借阅人id号
}books[100];
现在信息已经录完了,如何找出借阅次数最多的三本书,求求大佬们指点一下
遍历借阅信息,找到新书加入新数组,并记录数量1;检查完所有借阅信息后,对书的数量进行排序
struct book
{
char name[30];//图书名称
float price;//价格
int year;//借阅时间
int moth;
int day;
char id[20];//流水号
char user[10];//借阅人姓名
int userid;//借阅人id号
}books[100];
int n; //实际借阅数量
char bns[100][30] = {0}; //不同的书名称
int bn[100] = {0}; //不同的书数量
char temp[30];
int i,j,t,k=0;
for(i=0;i<n;i++)
{
for(j=0;j<k;j++)
if(strcmp(bns[k],books[i].name) == 0)
break;
if(j==k)
{
strcpy(bns[k++],books[i].name);
bn[k] = 1;
}
else
bn[j]++;
}
for(i=0;i<k-1;i++)
for(j=0;j<k-i-1;j++)
{
if(bn[j] < bn[j+1])
{
t = bn[j];
bn[j] = bn[j+1];
bn[j+1] = t;
strcpy(temp,bns[j]);
strcpy(bns[j],bns[j+1]);
strcpy(bns[j+1],temp);
}
}
printf("借阅最多的前三本书分别为:%s,%s,%s\n",bns[0],bns[1],bns[2]);