习题9-4 查找书籍 (20分)
给定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>
typedef struct{
char name[31];
double price;
}book;
book Max(book * lib, int n);
book Min(book * lib, int n);
int main()
{
int n;scanf("%d", &n);
book lib[n];
for (int i = 0; i < n; i++)
{
getchar(); //读取\n
gets(lib[i].name);
scanf("%lf", &lib[i].price);
}
book max = Max(lib, n);
book min = Min(lib, n);
printf("%.2lf, ", max.price);puts(max.name);
printf("%.2lf, ", min.price);puts(min.name);
return 0;
}
book Max(book * lib, int n)
{
int i, max = 0;
for (i = 0; i < n; i++)
{
if (lib[i].price > lib[max].price)
max = i;
}
book ret = {
.price = lib[max].price,
};
i = 0;
while (lib[max].name[i] != 0){
ret.name[i] = lib[max].name[i];
i++;
}
return ret;
}
book Min(book * lib, int n)
{
int i, min = 0;
for (i = 0; i < n; i++)
{
if (lib[i].price < lib[min].price)
min = i;
}
book ret = {
.price = lib[min].price
};
i = 0;
while (lib[min].name[i] != 0){
ret.name[i] = lib[min].name[i];
i++;
}
return ret;
}
版权声明:本文为mistymountain32原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。