实验9-5 查找书籍(结构体)

实验9-5 查找书籍 (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
struct book
{
	char name[100];
	double cost;
};
int main()
{
	struct book b[15];
	int n,i,index_min,index_max;
	int min=10000,max=-1;
	scanf("%d",&n);
	for(i=0;imax)
		{
			max=b[i].cost;
			index_max=i;
		}
	}
	printf("%.2lf, %s\n",b[index_max].cost,b[index_max].name);
	printf("%.2lf, %s\n",b[index_min].cost,b[index_min].name);
	
	return 0;
}

也可以使用另外两个结构变量来找最大最小值

#include 
struct book
{
    char name[32];  //书名
    double price;    //价格
}s[10], high, low;
int main()
{
    int n;
    scanf("%d", &n);
    for (int i = 0; i < n; i++)
    {
        scanf("\n");    //每次输入数字后都会有一个'\n',用scanf吞掉它
        gets(s[i].name);
        scanf("%lf",&s[i].price);
    }
        
    high = low = s[0];
    for (int i = 1; i < n; i++)
    {
        if (s[i].price > high.price)
            high = s[i];
        if (s[i].price < low.price)
            low = s[i];
    }
    printf("%.2lf, %s\n", high.price, high.name);
    printf("%.2lf, %s\n", low.price, low.name);

    return 0;
}

这里拿出这道题分享的原因是这道题的输入上有一个坑:

在输入一个数字后如果我们要使用%s来输入一个字符串的话,我们一定一定要注意!!!!!!

处理输入数字后面的‘\n’

你可能感兴趣的:(c语言)