7-5 查找书籍
分数 20
全屏浏览题目
作者 C课程组
单位 浙江大学
给定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
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
本题用struct结构体解决较为容易,但是要注意在scanf一个整数后,下面跟着一堆字符串和一个浮点数,而scanf一个浮点数后又跟着一堆字符串……所以要注意用getchar()消除scanf在缓冲区留下的回车。
ps:gets与scanf一样都是遇到回车才读入键盘输入的数据,但区别是gets遇到空格不会结束,且会将最后的回车读走,不会留在缓冲区。
源码:
#include<stdio.h>
#include<string.h>
struct book
{
char name[31];
double price;
};
int main()
{
int n;
scanf("%d",&n);
getchar();
struct book num[n];
for(int i=0;i<n;i++)
{
gets(num[i].name);
scanf("%lf",&num[i].price);
getchar();
}
double max=num[0].price;
int flag1;
for(int i=0;i<n;i++)
{
{
max=num[i].price;
flag1=i;
}
}
double min=num[0].price;
int flag2;
for(int i=0;i<n;i++)
{
if(min>num[i].price)
{
min=num[i].price;
flag2=i;
}
}
printf("%.2lf, %s\n",num[flag1].price,num[flag1].name);
printf("%.2lf, %s",num[flag2].price,num[flag2].name);
return 0;
}