习题9-4 查找书籍 (20分)

习题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版权协议,转载请附上原文出处链接和本声明。