NOIP2007奖学金问题及简单背包问题

引言:

最近刷了一些洛谷的基础算法题,关于排序类和贪心类,也发现了结构体用在这两种题目上的异曲同工之妙,那么我们废话不多说,直接上题目与解析帮助大家更好地掌握。

题目描述

某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前 55 名学生发奖学金。期末,每个学生都有 33 门课的成绩:语文、数学、英语。先按总分从高到低排序,如果两个同学总分相同,再按语文成绩从高到低排序,如果两个同学总分和语文成绩都相同,那么规定学号小的同学排在前面,这样,每个学生的排序是唯一确定的。

任务:先根据输入的 33 门课的成绩计算总分,然后按上述规则排序,最后按排名顺序输出前五名名学生的学号和总分。

注意,在前 55 名同学中,每个人的奖学金都不相同,因此,你必须严格按上述规则排序。例如,在某个正确答案中,如果前两行的输出数据(每行输出两个数:学号、总分) 是:

7 279  
5 279

这两行数据的含义是:总分最高的两个同学的学号依次是 77 号、55 号。这两名同学的总分都是 279279 (总分等于输入的语文、数学、英语三科成绩之和) ,但学号为 77 的学生语文成绩更高一些。

如果你的前两名的输出数据是:

5 279  
7 279

则按输出错误处理,不能得分。

输入格式

共 n+1 行。

第 1 行为一个正整数 n≤300,表示该校参加评选的学生人数。

第 2 到 n+1 行,每行有 3 个用空格隔开的数字,每个数字都在 0 到 100 之间。第 j 行的 3 个数字依次表示学号为 j−1 的学生的语文、数学、英语的成绩。每个学生的学号按照输入顺序编号为 1∼n(恰好是输入数据的行号减 1)。

保证所给的数据都是正确的,不必检验。

输出格式

共 5行,每行是两个用空格隔开的正整数,依次表示前 5 名学生的学号和总分。

输入输出样例

输入 #1复制

6
90 67 80
87 66 91
78 89 91
88 99 77
67 89 64
78 89 98

输出 #1复制

6 265
4 264
3 258
2 244
1 237

输入 #2复制

8
80 89 89
88 98 78
90 67 80
87 66 91
78 89 91
88 99 77
67 89 64
78 89 98

输出 #2复制

8 265
2 264
6 264
1 258
5 258

我们发现,排序的优先级是总分大的优先,总分相同则比较语文成绩,语文成绩相同则比较学号,学号小的同学排前面,这里需要注意,前面都是大的在前,唯有学号是小的在前,这是等下要编写的一个部分。

那我们来初步实现一下代码块:

代码块实现:

struct stu
{int num;int a,b,c;int sum;
}student[100005];

我们定义一个结构体部分负责接收学号,三科目成绩,总成绩等信息。

bool cmp(stu a,stu b)
{if(a.sum>b.sum){return 1;}else if(a.sum<b.sum){return 0;}else{if(a.y>b.y){return 1;}else if(a.y<b.y){return 0;}else{if(a.num<b.num){return 1;}else{return 0;}}}}

这里我们定义一个bool类型的比较函数,方便后续的排序中sort使用,我们依据推理逻辑,优先总分在先,再次语文,最后学号,注意是哪种情况该先排,哪种情况又该后排。

int main()
{int n;cin >> n;for(int i=1;i<=n;i++){student[i].num=i;cin >> student[i].yu >> student[i].shu >> student[i].eng;student[i].sum=student[i].yu+student[i].shu+student[i].eng;}sort(student+1,student+1+n,cmp);for(int i=1;i<=5;i++){cout << student[i].num << " " << student[i].sum << endl;}return 0;

这里是主函数的部分,注意结构体传数字时的操作,并使用sort根据上面的逻辑排序,最后输出即大功告成,这一题主要可以锻炼大家对于结构体与排序方法的掌握,很建议大家去做一下,最后完整代码和题目链接奉上:

#include <iostream>
#include <algorithm>
using namespace std;
struct stu
{int num;int yu,shu,eng;int sum;
}student[10005];
bool cmp(stu a,stu b)
{if(a.sum>b.sum){return 1;}else if(a.sum<b.sum){return 0;}else{if(a.yu>b.yu){return 1;}else if(a.yu<b.yu){return 0;}else{if(a.num>b.num){return 0;}else{return 1;}}}
}
int main()
{int n;cin >> n;for(int i=1;i<=n;i++){student[i].num=i;cin >> student[i].yu >> student[i].shu >> student[i].eng;student[i].sum=student[i].yu+student[i].shu+student[i].eng;}sort(student+1,student+1+n,cmp);for(int i=1;i<=5;i++){cout << student[i].num << " " << student[i].sum << endl;}return 0;
}

题目链接:https://www.luogu.com.cn/problem/P1093

部分背包问题:

在掌握了上一题之后,面对一部分的背包问题,我们是不是也可以使用异曲同工的方法来做出来呢?看下面这一题:

题目描述

阿里巴巴走进了装满宝藏的藏宝洞。藏宝洞里面有 N(N≤100) 堆金币,第 i 堆金币的总重量和总价值分别是 mi(1≤mi≤100),vi​​(1≤vi​≤100)。阿里巴巴有一个承重量为 (T≤1000) 的背包,但并不一定有办法将全部的金币都装进去。他想装走尽可能多价值的金币。所有金币都可以随意分割,分割完的金币重量价值比(也就是单位价格)不变。请问阿里巴巴最多可以拿走多少价值的金币?

输入格式

第一行两个整数 N,T。

接下来 N 行,每行两个整数 mi​,vi​。

输出格式

一个实数表示答案,输出两位小数

输入输出样例

输入 #1复制

4 50
10 60
20 100
30 120
15 45

输出 #1复制

240.00

首先,题目很明确了我们可以分割单块金币,以获得权重最大的金币(权重=价值/质量),我们肯定优先选择相同质量价值最高的金币堆,那么我们就可以对权重进行排序,再慢慢比较背包质量与金币质量,直到背包刚好装满为止。

结构体定义:

struct value
{int w,v;double jun;
}money[100005];

再定义比较函数:

bool cmp(Value a,Value b)
{if(a.jun>b.jun){return 1;}else{return 0;}
}

主函数部分:

int main()
{int n,t;cin >> n >> t;for(int i=0;i<n;i++){cin >> money[i].w >> money[i].v;money[i].jun=money[i].v/money[i].w;}sort(money,money+n,cmp);double sum;for(int i=0;i<n;i++){if(t>money[i].w){sum+=money[i].v;t-=money[i].w;}else{sum+=t*money[i].jun;break;}}printf("%.2lf",sum);return 0;

这一题我觉得主函数部分是难于自定义函数部分的操作的,还有最后这一个break操作,一定要记得加上,也就是背包最后装块的部分,装了以后背包就满了。最后,完整代码和题目地址奉上:

#include <iostream>
#include <algorithm> 
using namespace std;
struct Value
{double w,v;double jun;
}money[10005];
bool cmp(Value a,Value b)
{if(a.jun>b.jun){return 1;}else{return 0;}
}
int main()
{int n,t;cin >> n >> t;for(int i=0;i<n;i++){cin >> money[i].w >> money[i].v;money[i].jun=money[i].v/money[i].w;}sort(money,money+n,cmp);double sum;for(int i=0;i<n;i++){if(t>money[i].w){sum+=money[i].v;t-=money[i].w;}else{sum+=t*money[i].jun;break;}}printf("%.2lf",sum);return 0;
}

题目链接:https://www.luogu.com.cn/problem/P2240

总结:

今天给大家介绍了两个题目,它们的布局大体相同,主要是为了大家能够掌握使用结构体,排序,自定义函数的结合使用来解决问题,制作不易,给个点赞鼓励一下吧!

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

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

相关文章

整理git上的模板框架

vite-vue3.0-ts-pinia-uni-app 技术栈的app框架 功能&#xff1a;基于 uni-app&#xff0c;一端发布多端通用&#xff0c;目前已经适配 H5、微信小程序、QQ小程序、Ios App、Android App。 taro3vue3tsnutuipinia taro3 框架小程序跨端平台 vue3.0-element-vite-qiankun 后台…

优雅的使用ChromeDriver

在网页自动化测试中,我们经常需要控制浏览器执行各种操作。对于Python开发者来说,可以使用 Selenium 库来实现这一目的。Selenium需要与浏览器的驱动程序(Driver)配合使用,本文将介绍如何在Windows 11系统下载ChromeDriver并正确保存。 第一步:确定Chrome浏览器版本号 打开Ch…

HarmonyOS实战开发-如何构建多种样式弹窗

介绍 本篇Codelab将介绍如何使用弹窗功能&#xff0c;实现四种类型弹窗。分别是&#xff1a;警告弹窗、自定义弹窗、日期滑动选择器弹窗、文本滑动选择器弹窗。需要完成以下功能&#xff1a; 点击左上角返回按钮展示警告弹窗。点击出生日期展示日期滑动选择器弹窗。点击性别展…

计算机xinput1_3.dll丢失的解决方法,分享5种有效的解决方法

在计算机系统的运行过程中&#xff0c;当用户或应用程序试图访问某个特定功能时&#xff0c;可能会遇到“找不到xinput1_3.dll”这一错误提示。这个问题通常是由于系统文件缺失或损坏导致的。许多依赖于“xinput1_3.dll”文件的游戏、软件或工具在启动时会立即遭遇阻碍。由于该…

rust使用Command库调用cmd命令或者shell命令,并支持多个参数和指定文件夹目录

想要在不同的平台上运行flutter doctor命令&#xff0c;就需要知道对应的平台是windows还是linux&#xff0c;如果是windows就需要调用cmd命令&#xff0c;如果是linux平台&#xff0c;就需要调用sh命令&#xff0c;所以可以通过cfg!实现不同平台的判断&#xff0c;然后调用不同…

Excel·VBA数组分组问题

看到一个帖子《excel吧-数据分组问题》&#xff0c;对一组数据分成4组&#xff0c;使每组的和值相近 目录 代码思路1&#xff0c;分组形式、可分组数代码1代码2代码2举例 2&#xff0c;数组所有分组形式举例 这个问题可以转化为2步&#xff1a;第1步&#xff0c;获取一组数据…

QT 控件有突出感,定义控件边框

QT 控件有突出感&#xff0c;定义控件边框 1.设计师页面 在flat部分选中 这个时候按钮会失去边框如下图&#xff1a; 然后在.cpp文件中写入代码&#xff1a; ui->pushButton->setStyleSheet("border: 1px solid gray;");按钮就有了新的边框&#xff1a;

vant Circle 环形进度条写一个倒计时组件

要点&#xff1a; css旋转让元素平均分布在圆上setInterval函数事件小圆圈和环形进度条跳动的速度一致小程序开发环境 代码&#xff1a; html <van-circlevalue"{{ rate }}"stroke-width"6"color"{{ gradientColor }}"size"400rpx&q…

C++11入门手册第一节,学完直接上手Qt(共两节)

入门 hello.cpp #include <iostream>int main() { std::cout << "Hello Quick Reference\n"<<endl; return 0;} 编译运行 $ g hello.cpp -o hello$ ./hello​Hello Quick Reference 变量 int number 5; // 整数float f 0.95; //…

我不懂,到底找个什么样的工作,女朋友才会满意

烫 金三银四&#xff0c;最近要毕业季&#xff0c;感觉也是tm分手季了。。 又要找工作&#xff0c;又要搞毕业的事情&#xff0c;现在又出来个女朋友的事情 我真的要疯求了&#xff0c;我现在是已经找到了一个大厂&#xff0c;但是是白菜价&#xff0c;base北京&#xff0c;…

快排(六大排序)

快速排序 快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法&#xff0c;其基本思想为&#xff1a;任取待排序元素序列中的某元素作为基准值&#xff0c;按照该排序码将待排序集合分割成两子序列&#xff0c;左子序列中所有元素均小于基准值&#xff0c;右子序列中所…

vue router.js 传值,根据不同type显示不同内容

vue router.js 传值&#xff0c;根据不同type显示不同内容 el-bread 封装 router.js import Vue from vue import Router from vue-router// 路由前缀 const { prefixBasePath } require(../../config/basePath)// 解决重复点击一个路由报错问题 const originalPush Router…

yolov8本地、autodl环境配置、训练

目录 搭建本地环境安装miniconda3创建一个新的环境安装包 安装pycharm下载汉化导入解释器测试终端终端运行代码 YOLOv8本地训练数据集制作训练文件 YOLOv8 autodl训练流程注册账号充值选则服务器jupyterlab创建训练环境上传文件训练使用vscode SSH使用pycharm专业版SSH下载文件…

最大子序列(蓝桥杯,acwing,单调队列)

题目描述&#xff1a; 输入一个长度为 n 的整数序列&#xff0c;从中找出一段长度不超过 m 的连续子序列&#xff0c;使得子序列中所有数的和最大。 注意&#xff1a; 子序列的长度至少是 1。 输入格式&#xff1a; 第一行输入两个整数 n,m。 第二行输入 n 个数&#xff0…

Matlab|电动汽车充放电V2G模型

目录 1 主要内容 1.1 模型背景 1.2 目标函数 1.3 约束条件 2 部分代码 3 效果图 4 下载链接 1 主要内容 本程序主要建立电动汽车充放电V2G模型&#xff0c;采用粒子群算法&#xff0c;在保证电动汽车用户出行需求的前提下&#xff0c;为了使工作区域电动汽车尽可能多的消…

Mojo与Python——wsl安装mojo

文章目录 前言一、wsl设置二、安装步骤三、mojo初体验四、vscode联合开发总结 前言 此课程为系列课程&#xff0c;借助python语言来学习python语言的超集mojo。可以持续关注。 一、wsl设置 powershell查看wsl的版本&#xff0c;如果版本是1需要修改为2。 二、安装步骤 1.安装m…

浅试Kimi

最近KIMI大模型挺火的&#xff0c;擅长处理中文文本&#xff0c;咱也来试试吧&#xff01; 测试问题&#xff1a; 写一篇800字以上的短片小说&#xff1a;主要故事是以一位上进但其他方面表现平平的大男孩小贱&#xff0c;刚到公司不久&#xff0c;就被一位名叫大弟的女同事看…

HarmonyOS 应用开发之多端协同

多端协同流程 多端协同流程如下图所示。 图1 多端协同流程图 约束限制 由于“多端协同任务管理”能力尚未具备&#xff0c;开发者当前只能通过开发系统应用获取设备列表&#xff0c;不支持三方应用接入。 多端协同需遵循 分布式跨设备组件启动规则。 为了获得最佳体验&…

数据分析之Power BI

POWER QUERY 获取清洗 POWER PIVOT建模分析 如何加载power pivot 文件-选项-加载项-com加载项-转到 POWER VIEW 可视呈现 如何加载power view 文件-选项-自定义功能区-不在功能区中的命令-新建组-power view-添加-确定 POWER MAP可视地图

知识图谱与大数据:区别、联系与应用

目录 前言1 知识图谱1.1 定义1.2 特点1.3 应用 2 大数据2.1 定义2.2 应用 3. 区别与联系3.1 区别3.2 联系 结语 前言 在当今信息爆炸的时代&#xff0c;数据成为了我们生活和工作中不可或缺的资源。知识图谱和大数据是两个关键概念&#xff0c;它们在人工智能、数据科学和信息…