ZOJ List the Books 水~

来源:互联网 发布:淘宝万能评价语 编辑:程序博客网 时间:2024/05/16 08:33

http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1727

题目大意:

给你书名、出版时间、价格,让你按照一定的顺序排序。。

其中题目会给出优先级最高的,剩下两个按书名优先级>出版时间>价格来排序。


思路:

练习sort重载的。。。

不过sort(book,book+n,cmp_by_name);的重载函数竟然不能用引用。。不然会cp好吧,我习惯写重载<运算符了。

#include<cstdio>#include<cstring>#include<algorithm>using namespace std;const int MAXN=100+2;struct Book{char name[MAXN];int year,price;}book[MAXN];bool cmp_by_name(Book a,Book b){int k=strcmp(a.name,b.name);if(k < 0)return true;else if(k > 0)return false;return a.year < b.year || (a.year==b.year && a.price<b.price);}bool cmp_by_price(Book a,Book b){if(a.price < b.price)return true;else if(a.price > b.price)return false;int k=strcmp(a.name,b.name);if(k < 0)return true;else if(k > 0)return false;return a.year<b.year;}bool cmp_by_year(Book a,Book b){if(a.year < b.year)return true;else if(a.year > b.year)return false;int k=strcmp(a.name,b.name);if(k < 0)return true;else if(k > 0)return false;return a.price<b.price;}int main(){int n;int kase=0;while(~scanf("%d",&n),n){if(kase++)puts("");for(int i=0;i<n;i++)scanf("%s%d%d",book[i].name,&book[i].year,&book[i].price);char cmd[20];scanf("%s",cmd);if(strcmp(cmd,"Name")==0)sort(book,book+n,cmp_by_name);else if(strcmp(cmd,"Year")==0)sort(book,book+n,cmp_by_year);else if(strcmp(cmd,"Price")==0)sort(book,book+n,cmp_by_price);for(int i=0;i<n;i++)printf("%s %d %d\n",book[i].name,book[i].year,book[i].price);}return 0;}


3 0
原创粉丝点击