struct book
{
char name[30];//图书名称
float price;//价格
int year;//借阅时间
int moth;
int day;
char id[20];//流水号
char user[10];//借阅人姓名
int userid;//借阅人id号
}books[100];
现在信息已经录完了,如何找出借阅次数最多的三本书,求求大佬们指点一下

图书管理系统找出借阅次数最多的三本书
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- CSDN专家-link 2021-12-18 20:08关注
遍历借阅信息,找到新书加入新数组,并记录数量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]);
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用 1