一、概述
给定n本书的名称和定价,本题要求编写程序,查找并输出其中定价最高和最低的书的名称和定价。
输入格式:
输入第一行给出正整数n(<10),随后给出n本书的信息。每本书在一行中给出书名,即长度不超过30的字符串,随后一行中给出正实数价格。题目保证没有同样价格的书。
输出格式:
在一行中按照“价格, 书名”的格式先后输出价格最高和最低的书。价格保留2位小数。
二、样例
三、内存、时间要求
四、思路
1.创建一个结构体数组,用来分别存放书的价格与书名(书的价格一定要用double),书名用字符数组。
2.对结构体进行输入,最后一步没有回车,之后用一个循环和两个if语句找出最大最小值。
3.输出
五、代码
#include<stdio.h>
struct A {
double price;
char a[31];
};
//结构体
int main()
{
struct A temp;
int n, max=0, min=0;
scanf("%d\n", &n);//按输入样例后有个回车也可以用getchar()进行读取
struct A b[100];
for (int i = 0; i < n; i++) {
gets(b[i].a);
if(i!=n-1)
scanf("%lf\n", &(b[i].price));
else
{
scanf("%lf", &(b[i].price));
}
}
for (int i = 0; i < n; i++)
{
if (b[i].price>b[max].price)
{
max = i;
}
if (b[i].price < b[min].price)
{
min = i;
}
}
printf("%.2lf, %s\n", b[max].price, b[max].a);
printf("%.2lf, %s", b[min].price, b[min].a);
return 0;
}
求关注支持