PTA题目:找最贵的书和最便宜的书

给定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

分析:

这道题我真是服了,我在DEV-C++里,一遍过,直接写对,这个破PTA的编译器你是纯C或者纯C++,我不在乎。可你至少用新版的。这道题我做那么多题目遇到最离谱的。百度了那么多题解,和我写得思路一样。代码大致也对,可为什么我的就一直编译错误,头文件也对,你说gets不安全也改了,看了那么多博客,我终于知道这编译器差到什么样子。提交代码改了编译器环境还是那样。这里吐槽一下PTA的错误信息返回那里。太离谱了就不能说详细点,像编译器那样。不说了,累了。这里建议把编译器改成C提交,代码使用单一的语言,现在大多编译器都不是纯的,都是C与C++混合编译。下面给出答案。这个能过,但写得不好,算法可以优化,比如在输入的时候就已经比较完了,这种算法效率更高,大家可以自己尝试,博主不想看这道题了。

答案:

#include <stdio.h>
struct shu
{
    char a[31];
    double  b;
};
int main()
{
  int n,i,max=0,min=0;
    double temp;
    struct shu m[10];
    scanf("%d",&n);
	getchar();
    for(i=0;i<n;i++)
    {
        gets(m[i].a);//name
        scanf("%lf",&m[i].b);//price
		getchar();
    }
    for(i=1,temp=m[0].b;i<n;i++)
    {
        if(m[i].b>temp)
        { max=i;
        temp=m[i].b;}
    }
    
    for(i=1,temp=m[0].b;i<n;i++)
    {
        if(m[i].b<temp)
        { min=i;
        temp=m[i].b;}
    }
    printf("%.2lf, %s\n",m[max].b,m[max].a);
     printf("%.2lf, %s",m[min].b,m[min].a);
    return 0;
}
//这道题的编译器是我用过最离谱的,不接受反驳,在我的电脑上,0错误,0警告,程序也对,在这全是编译错误,查阅了文档改了,还提示编译错误,像个鬼一样。

如果觉得博主写得不错的话,就点个赞或者关注吧!

  • 9
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Tajang

感谢投喂

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值