噗 没读清题,用了个动态内存分配。。。原来这道题给定了不超过10本书,那就也可以定义数组来做啦。
另外求大佬解释一下float和double
#include<stdio.h>
#include<stdlib.h>
struct book{
char name[31];
double price; // 俺也不知道为啥价格要用双精度
}; // 一开始用的 float,答案就是不对,调试了老半天才发现呜呜呜呜呜
int main(void) // 求大神解答为啥这里 float和 double不一样
{
int i,n,max,min;
struct book *p;
scanf("%d", &n);
getchar(); // 处理一下回车
p = (struct book *)calloc(n,sizeof(struct book)); // 动态内存分配
for (i=0; i<n; i++){
gets((p+i)->name); // 因为书名有空格,所以用 gets()
scanf("%lf", &(p+i)->price);
getchar(); // 也是处理一下回车
}
max=min=0; // 假设最贵最便宜的都是第一个,然后逐一比较
for (i=0; i<n; i++){
if ((p+i)->price > (p+max)->price)
max = i;
if ((p+i)->price < (p+min)->price)
min = i;
}
printf("%.2f, %s\n", (p+max)->price, (p+max)->name);
printf("%.2f, %s\n", (p+min)->price, (p+min)->name);
free(p); // 最后别忘了释放动态内存
return 0;
}