给定n本书的名称和定价,本题要求编写程序,查找并输出其中定价最高和最低的书的名称和定价。
输入格式:
输入第一行给出正整数n(<10),随后给出n本书的信息。每本书在一行中给出书名,即长度不超过30的字符串,随后一行中给出正实数价格。题目保证没有同样价格的书。
输出格式:
在一行中按照“价格, 书名”的格式先后输出价格最高和最低的书。价格保留2位小数。
#include <stdio.h>
struct book{
double jiage;
char name[31];//字符串长度不超过三十,但字符数组带有\0,所以元素个数至少为31个
};
int main ()
{
int n,i,max,min;
scanf("%d\n",&n);
struct book b[n];//运用变长数组
for(i=0;i<n;i++)
{
gets(b[i].name);//对结构中的元素分别赋值
scanf("%lf",&b[i].jiage);
if(i!=n-1)
scanf("\n");
}
max=0,min=0;
for(i=0;i<n;i++)
{if(b[i].jiage>b[max].jiage)
{max=i;}
if(b[i].jiage<b[min].jiage)
{min=i;}
}
printf("%.2lf, %s\n",b[max].jiage,b[max].name);
printf("%.2lf, %s",b[min].jiage,b[min].name);
return 0;
}