给定n本书的名称和定价,本题要求编写程序,查找并输出其中定价最高和最低的书的名称和定价。
输入格式:
输入第一行给出正整数n(<10),随后给出n本书的信息。每本书在一行中给出书名,即长度不超过30的字符串,随后一行中给出正实数价格。题目保证没有同样价格的书。
输出格式:
在一行中按照“价格, 书名”的格式先后输出价格最高和最低的书。价格保留2位小数。
输入样例:
3
Programming in C
21.5
Programming in VB
18.5
Programming in Delphi
25.0
结尾无空行
输出样例:
25.00, Programming in Delphi
18.50, Programming in VB
结尾无空行
#include <stdio.h>
#define N 31 //多定义一些空间, 为字符串结尾的'\0'留下空间
struct book {
char name[N];
double price;
};
main() {
int n;
scanf("%d", &n);
struct book num[n];
int i = 0;
int max=0, min=0;
while(i < n) {
//scanf("\n");
getchar(); //十六十七行二选一就好了
//由于题目数据的读入格式是, 每读一个便换行, 而gets遇到换行符结束, 只会吃掉一个换行符
/*所以价格后面的换行符依旧留存于缓存区, 在下一次读入字符串前需要先把它清除
那么,有以下几种方法解决:
一、可以直接用scanf明确指定\n来吃掉(如第十六行)
二、可以通过getchar()吃掉 (如第十七行)
三、在第11行与第26行的占位符后面都加上\n
*/
gets(num[i].name);
scanf("%lf", &num[i].price);
//printf("%s %f\n", num[i].name, num[i].price);
if(num[i].price > num[max].price) max=i;
if(num[i].price < num[min].price) min=i;
i++;
}
printf("%.2f, %s\n%.2f, %s", num[max].price, num[max].name, num[min].price, num[min].name);
return 0;
}