实验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<stdio.h>
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;i<n;i++)
{
getchar(); //后面用gets()函数接收字符串
//,所以这里必须处理掉输入的回车,否则会让gets()接收到第一个字符为'\n'
gets(b[i].name);
scanf("%lf",&b[i].cost);
if(b[i].cost<min)
{
min=b[i].cost;
index_min=i;
}
if(b[i].cost>max)
{
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 <stdio.h> 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’