3D.处女座的训练(C++)

2023-12-02 22:58
文章标签 c++ 训练 3d 处女座

本文主要是介绍3D.处女座的训练(C++),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

处女座的训练(C++)

点击做题网站链接

题目描述
处女座靠着自己的家教本领赚够了去比赛的钱,于是开启了疯狂训练。在每个夜深人静第二天不收作业的夜晚,他都会开始刷题。
"今日又是一个刷题的夜晚。"他挑选了n道题开始刷,而题太多,刷不掉,理还乱(呜呜)、自己没有解决的题目每分钟都会给他带来 b i b_i bi的疲倦值,而解决每一道题目都需要花费 a i a_i ai分钟的时间。
当然,处女座一般都是考虑清楚了再写题的,所以他在写题的时候都会精神抖擞,也就是说,当前正在写的那一题并不会给他带来任何疲劳。
为了迎接后天要收的作业和明天要遇到的小姐姐,他想让今晚的刷题尽可能的轻松,那请你帮他找出最小所需要的疲倦值吧。

输入描述:
输入数据共包括n+1行,第一行包括一个n表示处女座今晚打算训练的题的数量。
接下来n行,每行包括两个整数 a i a_i ai, b i b_i bi,分别表示处女座刷掉本题要花费的时间和本题每分钟会带来的疲倦值。

输出描述:
一行包括一个整数,表示处女座今晚训练会产生的最小疲倦值。

示例1
输入

6
6 1
4 5
4 3
6 2
8 1
2 6

输出
86

说明
先做第6个题,增加(1+5+3+2+1)*2= 24 点疲倦值,再做第2个题,增加28点疲倦值,随后依次是第3,4,1,5道题,增加16,12,6点疲倦值。总共的疲倦值是24 + 28 + 16 + 12 + 6 = 86点。

备注:
2 ≤ N ≤ 1 0 5 2≤N≤10^5 2N105
2 ≤ a i ≤ 4 ⋅ 1 0 6 2≤a_i≤4⋅10^6 2ai4106
1 ≤ b i ≤ 1000 1≤b_i≤1000 1bi1000

题目分析:
贪心思想。按照 a i b i \frac{a_i}{b_i} biai作为关键字进行排序,按顺序完成作业即可。

解题代码:

#include <iostream>
#include <algorithm>
using namespace std;const int N = 1e+5;
struct st
{int a;//刷掉本题要花费的时间int b;//本题每分钟会带来的疲倦值
}questions[N];bool cmp(st x, st y)
{return x.a*y.b < x.b*y.a;
}int main()
{int n;cin >> n;long long ans=0,sum=0;for(int i=0;i<n;++i){cin >> questions[i].a >> questions[i].b;sum += questions[i].b;}sort(questions,questions+n,cmp);for(int i=0;i<n;++i){sum -= questions[i].b;ans += sum*questions[i].a;}cout << ans << endl;
}

错误解法:

#include <iostream>
#include <algorithm>
using namespace std;const int N = 1e+5;
struct st
{int a;//刷掉本题要花费的时间int b;//本题每分钟会带来的疲倦值
}questions[N];bool cmp(st x, st y)//两者唯一区别在于排序的不同,这边是先从小到大排a,如果a一样,则从大到小排b,这种排序是错误的
{if(x.a<y.a) return true;else{if(x.a==y.a){if(x.b>=y.b)return true;}}return false;
}int main()
{int n;cin >> n;long long ans=0,sum=0;for(int i=0;i<n;++i){cin >> questions[i].a >> questions[i].b;sum += questions[i].b;}sort(questions,questions+n,cmp);for(int i=0;i<n;++i){sum -= questions[i].b;ans += sum*questions[i].a;}cout << ans << endl;
}

这篇关于3D.处女座的训练(C++)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/447156

相关文章

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

C++11委托构造函数和继承构造函数的实现

《C++11委托构造函数和继承构造函数的实现》C++引入了委托构造函数和继承构造函数这两个重要的特性,本文主要介绍了C++11委托构造函数和继承构造函数的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、委托构造函数1.1 委托构造函数的定义与作用1.2 委托构造函数的语法1.3 委托构造函

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C

C++链表的虚拟头节点实现细节及注意事项

《C++链表的虚拟头节点实现细节及注意事项》虚拟头节点是链表操作中极为实用的设计技巧,它通过在链表真实头部前添加一个特殊节点,有效简化边界条件处理,:本文主要介绍C++链表的虚拟头节点实现细节及注... 目录C++链表虚拟头节点(Dummy Head)一、虚拟头节点的本质与核心作用1. 定义2. 核心价值二

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee