当前位置: 首页 > news >正文

C++ 刷题 使用到的一些有用的容器和函数

 优先队列

c++优先队列priority_queue(自定义比较函数)_c++优先队列自定义比较-CSDN博客

373. 查找和最小的 K 对数字 - 力扣(LeetCode)

官方题解:

class Solution {
public:vector<vector<int>> kSmallestPairs(vector<int>& nums1, vector<int>& nums2, int k) {auto cmp = [&nums1,&nums2](const pair<int,int>& a,const pair<int,int>& b) {return nums1[a.first] + nums2[a.second] > nums1[b.first] + nums2[b.second];};int m = nums1.size();int n = nums2.size();vector<vector<int>> ans;priority_queue<pair<int,int>,vector<pair<int,int>>,decltype(cmp)> pq(cmp);for(int i = 0;i < min(k,m);i++) {pq.emplace(i,0);}while(k-- > 0 && !pq.empty()) {auto [x,y] = pq.top();pq.pop();ans.emplace_back(initializer_list<int>{nums1[x],nums2[y]});if(y + 1 < n) {pq.emplace(x,y + 1);}}return ans;}
};

c++优先队列(priority_queue)用法详解_c++ 优先队列-CSDN博客

count函数

[C++] 基础教程 - std::count函数介绍和使用场景_std::cout-CSDN博客

std::count 是C++标准库的一个算法,用来计算给定值在指定范围内出现的次数

template <class InputIt, class T>
size_t count(InputIt first, InputIt last, const T& value);

使用场景:

#include <iostream>
#include <vector>
#include <algorithm>int main() {std::vector<int> nums = {1, 2, 3, 4, 5, 2, 3, 2};int target = 2;size_t count = std::count(nums.begin(), nums.end(), target);std::cout << "The number " << target << " appears " << count << " times in the array." << std::endl;return 0;
}
#include <iostream>
#include <string>
#include <algorithm>int main() {std::string str = "hello world";char target = 'l';size_t count = std::count(str.begin(), str.end(), target);std::cout << "The character '" << target << "' appears " << count << " times in the string." << std::endl;return 0;
}

相关文章:

  • 计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-09-25
  • Golang | Leetcode Golang题解之第417题太平洋大西洋水流问题
  • OpenHarmony标准系统mipi摄像头适配
  • EchartJs报表展示
  • 【HarmonyOS】深入理解@Observed装饰器和@ObjectLink装饰器:嵌套类对象属性变化
  • 403高效绕过目录扫描工具
  • 《C++魔法:零开销实现抽象工厂模式》
  • ES数据的删除与备份
  • 2024年研究生数学建模“华为杯”E题——肘部法则、k-means聚类、目标检测(python)、ARIMA、逻辑回归、混淆矩阵(附:目标检测代码)
  • 微服务注册中⼼1
  • springboot实战学习(7)(JWT令牌的组成、JWT令牌的使用与验证)
  • Playerprefer类中的方法
  • 【Kubernetes】日志平台EFK+Logstash+Kafka【实战】
  • Vue引入js脚本问题记录(附解决办法)
  • 数据库 - MySQL数据查询
  • angular学习第一篇-----环境搭建
  • css选择器
  • egg(89)--egg之redis的发布和订阅
  • github从入门到放弃(1)
  • iOS高仿微信项目、阴影圆角渐变色效果、卡片动画、波浪动画、路由框架等源码...
  • JS实现简单的MVC模式开发小游戏
  • Kibana配置logstash,报表一体化
  • Quartz实现数据同步 | 从0开始构建SpringCloud微服务(3)
  • webpack项目中使用grunt监听文件变动自动打包编译
  • 对话:中国为什么有前途/ 写给中国的经济学
  • 猴子数据域名防封接口降低小说被封的风险
  • 如何学习JavaEE,项目又该如何做?
  • 深度学习入门:10门免费线上课程推荐
  • 实现简单的正则表达式引擎
  • 学习使用ExpressJS 4.0中的新Router
  • Prometheus VS InfluxDB
  • ​油烟净化器电源安全,保障健康餐饮生活
  • # 数论-逆元
  • #07【面试问题整理】嵌入式软件工程师
  • #我与Java虚拟机的故事#连载10: 如何在阿里、腾讯、百度、及字节跳动等公司面试中脱颖而出...
  • $forceUpdate()函数
  • (+4)2.2UML建模图
  • (14)目标检测_SSD训练代码基于pytorch搭建代码
  • (Java)【深基9.例1】选举学生会
  • (pojstep1.3.1)1017(构造法模拟)
  • (笔记)M1使用hombrew安装qemu
  • (差分)胡桃爱原石
  • (回溯) LeetCode 131. 分割回文串
  • (三十五)大数据实战——Superset可视化平台搭建
  • (原創) X61用戶,小心你的上蓋!! (NB) (ThinkPad) (X61)
  • (正则)提取页面里的img标签
  • (转)四层和七层负载均衡的区别
  • (转)为C# Windows服务添加安装程序
  • (转载)Linux网络编程入门
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • **登录+JWT+异常处理+拦截器+ThreadLocal-开发思想与代码实现**
  • .net redis定时_一场由fork引发的超时,让我们重新探讨了Redis的抖动问题
  • .net 重复调用webservice_Java RMI 远程调用详解,优劣势说明
  • .NET/C# 在 64 位进程中读取 32 位进程重定向后的注册表
  • .netcore 如何获取系统中所有session_ASP.NET Core如何解决分布式Session一致性问题