读不懂语法的程序猿 2022-11-19 20:08 采纳率: 86.5%
浏览 0
已结题

P1478 陶陶摘苹果(升级版)

问题遇到的现象和发生背景

img

img

P1478 陶陶摘苹果(升级版)
输出结果为7,不知道哪里错了。

用代码块功能插入代码,请勿粘贴截图
#include <stdio.h>
int x[5005],y[5005],z[5005];
int main ()
{
    int n,s,a,b,sum=0,temp,count=0;
    scanf("%d&d",&n,&s);
    scanf("%d%d",&a,&b);
    for(int i=0;i<n;i++)
        scanf("%d%d",&x[i],&y[i]);
    for(int j=0;j<n;j++)
    {
        if(x[j]<=a+b)
            z[sum++]=y[j];
    }
    for(int i=1;i<sum;i++)
        for(int j=0;j<sum-i;j++)
        {
            if(z[j]>z[j+1])
            {
                temp=z[j+1];
                z[j+1]=z[j];
                z[j]=temp;
            }
        }
    for(int i=0;i<sum&&s>=z[i];i++)
    {
        s-=z[i];
        count++;
    }
    printf("%d",count);
    return 0;
}
  • 写回答

2条回答 默认 最新

  • 游坦之 全栈领域优质创作者 2022-11-19 23:55
    关注
    
    #include<bits/stdc++.h>
    using namespace std;
    struct apple{
        int high;
        int liqi;
    }aa[5001];
    bool cmp(apple a,apple b){
        return a.liqi<b.liqi;
    }
    int main(){
            int n,s,a,b,ans=0;
            cin>>n>>s>>a>>b;
            for(int i=0;i<n;i++){
                scanf("%d%d",&aa[i].high,&aa[i].liqi);
            }
            sort(aa,aa+n,cmp);
            for(int i=0;i<n;i++){
                if(s<=0) break;
                if(aa[i].high<=(a+b) && aa[i].liqi<=s){
                    ans++;
                    s-=aa[i].liqi;
                }
            }
            cout<<ans<<endl;
            return 0;
    }
    

    这个咋样?有用记得采纳 呐

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月3日
  • 已采纳回答 11月25日
  • 修改了问题 11月19日
  • 创建了问题 11月19日

悬赏问题

  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用