图书管理系统找出借阅次数最多的三本书

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