笔记90:C++中sort函数的使用

函数原型:sort ( iterator beg , iterator end , _Pred )

a

a

参数介绍:

  • beg:起始迭代器
  • end:终止迭代器
  • Pred:谓词(如果不给,默认使用 less<int>() 作为谓词,排序方式为从小到大)

a

a

作用:将迭代器beg和end之间的元素进行排序

a

a

注意1:使用之前包含头文件 <functional>,这个函数不是STL中定义的;

注意2:如果用STL中定义的针对某个容器类型的sort函数,则要包含头文件 <algorithm>;

注意3:定义的比较函数一定要加关键字【static】;

注意4:排序函数内部实现为快排,排序的时间复杂度为 O(n * logn) ;

a

a

补充文章:

https://www.cnblogs.com/BlueBlueSea/p/14030217.html

C++中sort()函数第三个参数(比较函数)为什么要声明为 static?-CSDN博客

不想自己编写排序函数,可以直接使用已经定义好的仿函数:

a

a

如果想对容器中的元素从小到大排序:

  1. sort ( iterator beg , iterator end )
  2. sort ( iterator beg , iterator end , less<int>() )

如果想对容器中的元素从大到小排序:

  1. sort ( iterator beg , iterator end , greater<int>() )

如何编写排序函数:

举例1:

例1:Leetcode_1005_K次取反后最大化的数组和

链接:. - 力扣(LeetCode)

class Solution {
static bool PaiXv(int a, int b) {return abs(a) > abs(b);
}public:int largestSumAfterKNegations(vector<int>& nums, int k) {sort(nums.begin(), nums.end(), PaiXv);for (int i = 0; i < nums.size(); i++) {if (nums[i] < 0 && k > 0) {nums[i] *= -1;k--;}}if (k % 2 == 1) nums[nums.size() - 1] *= -1;int result = 0;for (int a : nums) result += a;return result;}
};

注意1:代码中定义的排序是从大到小

注意2:数值a和b都是按照数组nums中元素原本的顺序传递进来的,如果想让其从大到小排列,就需要这么写;如果a和b确实是按照从大到小排列的,就返回true,否则就返回false;

举例2:

例2:Leetcode_406_根据身高体重建队列

链接:. - 力扣(LeetCode)

class Solution {
public:static bool compare(vector<int> v1, vector<int> v2) {if(v1[0] > v2[0]) return true;else if(v1[0] == v2[0] && v1[1] < v2[1]) return true;return false;}vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {sort(people.begin(), people.end(), compare);vector<vector<int>> result;result.push_back(people[0]);for(int i = 1; i < people.size(); i++) {result.insert(result.begin() + people[i][1], people[i]);}return result;}
};

注意:代码中定义的排序顺序是先按首元素排序,首元素相同则按次元素排序;

  • 排序前:people = [ [7,0] , [4,4] , [7,1] , [5,0] , [6,1] , [5,2] ]
  • 排序后:people = [ [7,0] , [7,1] , [6,1] , [5,0] , [5,2] , [4,4] ]

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

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

相关文章

windows系统电脑外插键盘驱动出现感叹号或者显示未知设备,键盘无法输入的解决办法

笔记本外插的键盘不能用&#xff0c;鼠标可以使用。 查找故障&#xff0c;结果打开设备管理器看到键盘那项里是一个的黄色惊叹号显示未知设备&#xff01;[图片]如下图所示 其实解决办法很简单&#xff0c;不要相信网上的一些博主说删除什么注册表&#xff0c;我开始跟着他们操…

[每日一练]按日期分组销售产品的最优解法

该题目来自于力扣的pandas题库&#xff0c;链接如下&#xff1a; 1484. 按日期分组销售产品 - 力扣&#xff08;LeetCode&#xff09; 题目要求&#xff1a; 表 Activities&#xff1a; ---------------------- | 列名 | 类型 | ---------------------- | sell_…

Jetpack架构组件_5.BindingAdapter

1.BindingAdapter介绍 Binding adapters 可以作为一个设置某个值的框架来使用&#xff0c;databinding 库可以允许指定具体的方法来进行相关值的设置&#xff0c;在该方法中可以做一些处理逻辑&#xff0c;Binding adapters 会最终给你想要的结果。Android Databinding框架中已…

embedding模型API启动

Embedding模型API启动 针对一些需要使用api调用的大模型框架&#xff08;如fastGPT&#xff09;&#xff0c;可以用该方法启动Embedding模型 环境问题不过多赘述&#xff0c;代码如下 import uvicorn from pydantic import BaseModel # , Field from fastapi.middleware.co…

创建一个乘法练习题生成器 using Java

在教育软件和家庭学习辅助工具中&#xff0c;自动生成练习题是一种常见的需求&#xff0c;它能够帮助学生通过大量练习来巩固数学基础概念。本文将介绍如何使用Java编程语言创建一个简单的乘法练习题生成器&#xff0c;该程序不仅能够随机生成乘法题目&#xff0c;还能保证输出…

【本地运行chatgpt-web】启动前端项目和service服务端项目,也是使用nodejs进行开发的。两个都运行成功才可以使用!

1&#xff0c;启动web界面 https://github.com/Chanzhaoyu/chatgpt-web#node https://nodejs.org/en/download/package-manager # 使用nvm 安装最新的 20 版本。 curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash source /root/.bashrc n…

自力更生:0依赖三方库,手把手教你打造专属C++测试框架

前言&#xff1a; 当人们谈到测试框架的时候&#xff0c;首先想到的就是 google 的 gtest&#xff0c; 想着怎么在代码中集成 gtest 的框架&#xff0c;来实现自身代码的测试。 然后就巴拉巴拉的费了老大劲将 gtest 嵌入到自己的代码中来。 诚然&#xff0c;在自身程序接口稳…

huggingface的self.state与self.control来源(TrainerState与TrainerControl)

文章目录 前言一、huggingface的trainer的self.state与self.control初始化调用二、TrainerState源码解读(self.state)1、huggingface中self.state初始化参数2、TrainerState类的Demo 三、TrainerControl源码解读(self.control)总结 前言 在 Hugging Face 中&#xff0c;self.s…

C语言实现十进制转任意进制(详解)

主要思路&#xff1a;运用一个数组&#xff0c;通过数字每次取任意进制模&#xff0c;存在数组中&#xff0c; 再通过倒取数组中的数值&#xff0c;来实现进制转换&#xff0c;如果遇到十六进制&#xff0c;利用ASCII码值 数字字符和大写字母 相差55的特性来解决 int main() {…

【芯片验证方法】

术语——中文术语 大陆与台湾的一些术语存在差别&#xff1a; 验证常用的英语术语&#xff1a; 验证&#xff1a;尽量模拟实际应用场景&#xff0c;比对芯片的所需要的目标功能和实现的功能 影响验证的要素&#xff1a;应用场景、目标功能、比对应用场景、目标功能&#xff…

内存泄露和内存溢出有什么不同

内存泄露和内存溢出是两个常见的内存问题&#xff0c;它们在程序运行过程中可能导致性能下降、系统不稳定甚至应用崩溃。虽然这两个术语经常被混用&#xff0c;但它们描述的是两种不同的问题&#xff1a; 内存泄露&#xff08;Memory Leak&#xff09; 内存泄露是指程序在分配…

华发股份:加强业务协同 新政下项目热销

“5.17”楼市政策出台后&#xff0c;各地密集落地执行。5月27—28日&#xff0c;上海、广州、深圳三个一线城市跟进落地“517”新政。上海发布《关于优化本市房地产市场平稳健康发展政策措施的通知》&#xff0c;共计9条调整政策&#xff0c;涵盖外地户籍、人才、单身、婚否、企…

一个生动的例子——通过ERC20接口访问Tether合约

生动的例子 USDT&#xff1a;符合ERC20标准的美元稳定币&#xff0c;Tether合约获得测试网上Tether合约地址通过自己写的ERC20接口访问这个合约 Tether合约地址&#xff1a;0xdAC17F958D2ee523a2206206994597C13D831ec7 IERC20.sol // SPDX-License-Identifier: GPL-3.0pra…

今日分享站

同志们&#xff0c;字符函数和字符串函数已经全部学习完啦&#xff0c;笔记也已经上传完毕&#xff0c;大家可以去看啦。字符函数和字符串函数and模拟函数 加油&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;

Unix环境高级编程--7-进程环境--7.1-7.2main函数-7.3进程退出

1、几个问题 ①main函数如何被调用&#xff1f; ②命令行参数如何传递给新程序&#xff1f;&#xff1b; ③典型储存空间布局是什么样的&#xff1f;&#xff1b; ④进程如何使用环境变量 &#xff1f;&#xff1b; ⑤进程的各种终止方式&#xff1f; 2、main函数 当内核…

列表推导式(解析式)python

Python中的列表推导式&#xff08;list comprehension&#xff09;是一种简洁且强大的语法&#xff0c;用于创建新的列表。它允许你通过对现有列表中的元素进行操作或筛选来快速生成新列表。以下是列表推导式的基本语法和一些示例&#xff1a; 基本语法&#xff1a; new_list…

vue3的组件通信v-model使用

一、组件通信 1.props 》 父向子传值 props 主要用于父组件向子组件通信。再父组件中通过使用:msgmsg绑定需要传给子组件的属性值&#xff0c;然后再在子组件中用props接收该属性值 方法一 普通方式:// 父组件 传值<child :msg1"msg1" :list"list">…

Dinky MySQLCDC 整库同步到 Doris

资源&#xff1a;flink 1.17.0、dinky 1.0.2、doris-2.0.1-rc04 问题&#xff1a;Cannot deserialize value of type int from String &#xff0c;detailMessageunknowndatabases &#xff0c;not a valid int value 2024-05-29 16:52:20.136 ERROR org.apache.doris.flink.…

最长公共子序列问题的求解

假设有两个字符串A和B&#xff0c;A字符串的组成为 A A 0 A 1 A 2 . . . . . . A n − 1 A A_0A_1A_2......A_{n-1} AA0​A1​A2​......An−1​ B B 0 B 1 B 2 . . . . . . B m − 1 BB_0B_1B_2......B_{m-1} BB0​B1​B2​......Bm−1​ 要寻找这两个字符串的公共子序列还…

MS Excel: 高亮当前行列 - 保持原有格式不被改变

本文使用条件格式VBA的方法实现高亮当前行列&#xff0c;因为纯VBA似乎会清除原有的高亮格式。效果如下&#xff1a;本文图省事就使用同一种颜色了。 首先最重要的&#xff0c;【选中你期望高亮的单元格区域】&#xff0c;比如可以全选当前sheet的全部区域 然后点击【开始】-【…