newOJ-1093: 分香蕉

目录

题目链接:

思路:

坑一:

坑二:

坑三:

代码:

通过10%:

 通过80%:

通过100%:


题目链接:

P1093 - 分香蕉 - New Online Judge (ecustacm.cn)


思路:

结构体排序

坑一:

对结构体不熟练

回顾相关知识点:一定要多复习几遍

c语言基础语法六——结构体(完结)-CSDN博客


坑二:

最后是“按照输入顺序”输出对应猴子对应的香蕉总数。

所以要提前把输入序号记下来,最后恢复,然后再输出。


坑三:

记得break


代码:

通过10%:

原因:没看清题,人家要按原来的输入顺序输出!!!

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+3;
int banana[N];struct monkey{int weight;int sum;
}monk[N];bool cmp(monkey A,monkey B){if(A.weight>B.weight){return true;}else return false;
}int main(){int n,m;cin>>n>>m;for(int i=0;i<n;i++){cin>>banana[i]; //banana[i]表示第i个香蕉的质量}for(int i=0;i<m;i++){cin>>monk[i].weight; //monkey[i]表示第i个猴子的体重monk[i].sum=0; //monkey[i]表示第i个猴子获得的香蕉的质量之和}sort(banana,banana+n,greater<int>());//sort(monkey,monkey+n,greater<int>());  //注意greater适用的是int的,所以结构体的比较不适用sort(monk,monk+m,cmp);for(int i=0;i<n;){for(int j=0;j<m;j++){monk[j].sum+=banana[i];i++;}}for(int i=0;i<m;i++){cout<<monk[i].sum<<" ";}return 0;
}


 通过80%:

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+3;
int banana[N];struct monkey{int weight;int sum;int id;
}monk[N];bool cmp(monkey A,monkey B){if(A.weight>B.weight){return true;}else return false;
}bool cmp2(monkey A,monkey B){if(A.id<B.id){return true;}else return false;
}int main(){int n,m;cin>>n>>m;for(int i=0;i<n;i++){cin>>banana[i]; //banana[i]表示第i个香蕉的质量}for(int i=0;i<m;i++){cin>>monk[i].weight; //monkey[i]表示第i个猴子的体重monk[i].sum=0; //monkey[i]表示第i个猴子获得的香蕉的质量之和monk[i].id=i;}sort(banana,banana+n,greater<int>());//sort(monkey,monkey+n,greater<int>());  //注意greater适用的是int的,所以结构体的比较不适用sort(monk,monk+m,cmp);for(int i=0;i<n;){for(int j=0;j<m;j++){monk[j].sum+=banana[i];i++;}}sort(monk,monk+m,cmp2); //按编号排序,也就是回到初始排序for(int i=0;i<m;i++){cout<<monk[i].sum<<" ";}return 0;
}

通过100%:

应该还得加个判断,if(i>=n){break;}

因为如果不break,可能会超过N,造成数组越界。

要是开了很大的数组,最后都break一下

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+3;
int banana[N];struct monkey{int weight;int sum;int id;
}monk[N];bool cmp(monkey A,monkey B){if(A.weight>B.weight){return true;}else return false;
}bool cmp2(monkey A,monkey B){if(A.id<B.id){return true;}else return false;
}int main(){int n,m;cin>>n>>m;for(int i=0;i<n;i++){cin>>banana[i]; //banana[i]表示第i个香蕉的质量}for(int i=0;i<m;i++){cin>>monk[i].weight; //monkey[i]表示第i个猴子的体重monk[i].sum=0; //monkey[i]表示第i个猴子获得的香蕉的质量之和monk[i].id=i;}sort(banana,banana+n,greater<int>());//sort(monkey,monkey+n,greater<int>());  //注意greater适用的是int的,所以结构体的比较不适用sort(monk,monk+m,cmp);for(int i=0;i<n;){for(int j=0;j<m;j++){monk[j].sum+=banana[i];i++;if(i>=n){break;}}}sort(monk,monk+m,cmp2); //按编号排序,也就是回到初始排序for(int i=0;i<m;i++){cout<<monk[i].sum<<" ";}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/782273.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RVM安装Ruby笔记(Mac)

环境 硬件&#xff1a;Macbook Pro 系统&#xff1a;macOS 14.1 安装公钥 通过gpg安装公钥失败&#xff0c;报错如下&#xff1a; 换了几个公钥地址&#xff08;hkp://subkeys.pgp.net&#xff0c;hkp://keys.gnupg.net&#xff0c;hkp://pgp.mit.edu&#xff09;&#xff0c;…

使用Flink实现MySQL到Kafka的数据流转换

使用Flink实现MySQL到Kafka的数据流转换 本篇博客将介绍如何使用Flink将数据从MySQL数据库实时传输到Kafka&#xff0c;这是一个常见的用例&#xff0c;适用于需要实时数据connector的场景。 环境准备 在开始之前&#xff0c;确保你的环境中已经安装了以下软件&#xff1a;…

ML-Decoder: Scalable and Versatile Classification Head

1、引言 论文链接&#xff1a;https://openaccess.thecvf.com/content/WACV2023/papers/Ridnik_ML-Decoder_Scalable_and_Versatile_Classification_Head_WACV_2023_paper.pdf 因为 transformer 解码器分类头[1] 在少类别多标签分类数据集上表现得很好&#xff0c;但由于其查询…

公平抽签(蓝桥杯)

文章目录 公平抽签题目描述回溯算法 公平抽签 题目描述 小A的学校&#xff0c;蓝桥杯的参赛名额非常有限&#xff0c;只有 m 个名额&#xff0c;但是共有 n 个人报名。 作为老师非常苦恼&#xff0c;他不知道该让谁去&#xff0c;他在寻求一个绝对公平的方式。 于是他准备让…

PHP的定时任务框架的taskPHP3.0学习记录2(环境要求、配置Redis、crontab执行时间语法、命令操作以及Screen全屏窗口管理器)

环境要求 php版本> 5.5开启socket扩展开启pdo扩展开启shmop扩展 echo <pre>; echo --; $requiredVersion 5.6.0; $currentVersion phpversion(); if (version_compare($currentVersion, $requiredVersion, >)) {echo "1.PHP版本满足要求&#xff0c;当前版…

c语言:vs2022写一个一元二次方程(包含虚根)

求一元二次方程 的根&#xff0c;通过键盘输入a、b、c&#xff0c;根据△的值输出对应x1和x2的值(保留一位小数)(用if语句完成)。 //一元二次方程的实现 #include <stdio.h> #include <math.h> #include <stdlib.h> int main() {double a, b, c, delta, x1…

数据结构 - 算法效率|时间复杂度|空间复杂度

目录 1.算法效率 2.时间复杂度 2.1定义 2.2大O渐近表示法 2.3常见时间复杂度计算举例 3.空间复杂度 3.1定义 3.2常见空间复杂度计算举例 1.算法效率 算法的效率常用算法复杂度来衡量&#xff0c;算法复杂度描述了算法在输入数据规模变化时&#xff0c;其运行时间和空间…

opejdk11 java 启动流程 java main方法怎么被jvm执行

java启动过程 java main方法怎么被jvm执行 java main方法是怎么被jvm调用的 1、jvm main入口 2、执行JLI_Launch方法 3、执行JVMInit方法 4、执行ContinueInNewThread方法 5、执行CallJavaMainInNewThread方法 6、创建线程执行ThreadJavaMain方法 7、执行ThreadJavaMain方法…

Last-Modified:HTTP缓存控制机制解析

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

docker配置github仓库ghcr国内镜像加速

文章目录 说明ghcr.io简介配置镜像命令地址命令行方式1panel面板方式方式一&#xff1a;配置镜像加速&#xff0c;命令行拉取方式二&#xff1a;配置镜像仓库&#xff0c;可视化拉取 说明 由于使用的容器需要从github下载镜像&#xff0c;服务器在国外下载速度很慢&#xff0c…

26. UE5 RPG同步面板属性(二)

在上一篇&#xff0c;我们解析了UI属性面板的实现步骤&#xff1a; 首先我们需要通过c去实现创建GameplayTag&#xff0c;这样可以在c和UE里同时获取到Tag创建一个DataAsset类&#xff0c;用于设置tag对应的属性和显示内容创建AttributeMenuWidgetController实现对应逻辑 并且…

理解游戏服务器架构-部署架构

目录 前言 我所理解的服务器架构 什么是否部署架构 部署架构的职责 进程业务职责 网络链接及通讯方式 与客户端的连接方式 服务器之间连接关系 数据落地以及一致性 数据库的选择 数据访问三级缓存 数据分片 读写分离 分布式数据处理 负载均衡 热更新 配置更新 …

html第二次作业

骨架 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-width, initi…

vscode初始化node项目

首先需要安装node环境&#xff0c;推荐直接使用nvm 安装node&#xff0c;方便切换node版本 1.npm init 初始化node项目 在命令行输入npm init指令 根据指令创建完成后会在当前目录下生成一个package.json文件&#xff0c;记住运行npm init执行的目录必须是一个空目录 2.创建…

蓝桥杯算法题-发现环

问题描述   小明的实验室有N台电脑&#xff0c;编号1~N。原本这N台电脑之间有N-1条数据链接相连&#xff0c;恰好构成一个树形网络。在树形网络上&#xff0c;任意两台电脑之间有唯一的路径相连。    不过在最近一次维护网络时&#xff0c;管理员误操作使得某两台电脑之间增…

vue实现相机拍摄,可录视频、拍照片、前置后置切换(简单小demo)

内容比较简单&#xff0c;不做过多赘述&#xff0c;只做分享&#xff0c;测试demo&#xff0c;功能有些缺陷&#xff0c;希望路过的大佬多多指正 /(*/ω&#xff3c;*) <script setup> import { showToast, showSuccessToast, showFailToast, showLoadingToast } from …

VUE3——reactive对比ref

从定义数据角度对比: 。ref用来定义:基本类型数据 。reactive用来定义:对象(或数组)类型数据。 。备注:ref也可以用来定义对象(或数组)类型数据,它内部会自动通过 reactive 转为代理对象。 从原理角度对比: 。ref通过 object.defineProperty()的 get 与set 来实现响应式(数据劫…

算法题1两数之和

问题&#xff1a;给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。 你可以…

金三银四面试题(八):JVM常见面试题(2)

今天我们继续探讨常见的JVM面试题。这些问题不比之前的问题庞大&#xff0c;多用于面试中​JVM部分的热身运动&#xff0c;开胃菜&#xff0c;但是大家已经要认真准备。 JRE、JDK、JVM 及JIT 之间有什么不同&#xff1f; JRE 代表Java 运行时&#xff08;Java run-time&#…

专升本-数字媒体

数字媒体 概念&#xff1a; 媒体&#xff1a;是信息的载体&#xff0c;传播信息的媒介&#xff0c;能为信息的传播提供平台 数字媒体&#xff1a;多重媒体&#xff0c;使用文字&#xff0c;数据&#xff0c;图像&#xff0c;声音等各种媒体 数字媒体技术&#xff1a;利用计…