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

acwing算法基础之基础算法--整数离散化算法

目录

  • 1 知识点
  • 2 模板

1 知识点

整个范围很大,但存在的数据点很少。比如从 − 1 0 9 -10^9 109 1 0 9 10^9 109,但总共只有 1 0 6 10^6 106个数。

可以采用离散化的思想来做,即将离散的大数值映射成连续的小数值(一般是 1 , 2 , 3 , ⋯ , n 1,2,3,\cdots,n 1,2,3,,n)。

看到这里,你是不是觉得小数值与向量下标比较相似,是的,它本质就是下标,从1开始编号还是从0开始编号,取决于业务逻辑。acwing讲解例题中是从1开始编号的。

2 模板

//输入是向量vector<int>alls
//输出是函数find(),输入大数值得到小数值
sort(alls.begin(), alls.end());
alls.erase(unique(alls.begin(), alls.end()), alls.end());int find(vector<int> &alls, int x) { //找到大于等于x的第1个下标,题目中保证一定存在xint l = 0, r = alls.size() - 1;while (l < r) {int mid = (l + r) / 2;if (alls[mid] >= x) {r = mid;} else {l = mid + 1;}}return l + 1;//从1开始编号。如果返回l,表示从0开始编号。
} //其中unique()函数使用的是库函数,也可以自己实现,如下所示
vector<int>::iterator unique(vector<int> &a) {int j = 0;for (int i = 0; i < a.size(); ++i) {if (i == 0 || a[i] != a[i-1]) {a[j++] = a[i]; }}return a.begin() + j;
}

当然,上述模板也可以用哈希表来实现,如下,

//输入是向量vector<int>alls
//输出是哈希表mp,输入大数值得到小数值
sort(alls.begin(), alls.end());
alls.erase(unique(alls.begin(), alls.end()), alls.end());unordered_map<int,int> mp;
for (int i = 0; i < alls.size(); ++i) {mp[alls[i]] = i + 1; //从1开始编号。如果写i,表示从0开始编号。
}
http://www.lryc.cn/news/191993.html

相关文章:

  • 基于SSM框架的安全教育平台
  • Kafka生产者使用案例
  • EasyX图形库实现贪吃蛇游戏
  • 利用 Amazon CodeWhisperer 激发孩子的编程兴趣
  • 2023年中国分子筛稀土催化材料竞争格局及行业市场规模分析[图]
  • vue3插件——vue-web-screen-shot——实现页面截图功能
  • 简单总结Centos7安装Tomcat10.0版本
  • ffmpeg中AVCodecContext和AVCodec的关系分析
  • 2023年中国门把手产量、销量及市场规模分析[图]
  • HTML 核心技术点基础详细解析以及综合小案例
  • BAT学习——批处理脚本(也称为BAT文件)常用语法元素与命令
  • AMD AFMF不但能用在游戏,也适用于视频
  • CSS 常用样式浮动属性
  • Linux引导故障排除:从问题到解决方案的详细指南
  • 【vim 学习系列文章 6 -- vim 如何从上次退出的位置打开文件】
  • 怎样学习C#上位机编程?
  • 【算法-动态规划】两个字符串的删除操作-力扣 583
  • 【06】基础知识:typescript中的泛型
  • flutter 绘制原理探究
  • [Java]SPI扩展功能
  • 机器人命令表设计
  • STM32--WDG看门狗
  • (※)力扣刷题-字符串-实现 strStr()(KMP算法)
  • Redis 集群 Redis 事务 Redis 流水线 Redis 发布订阅 Redis Lua脚本操作
  • 【算法与数据结构】--常见数据结构--栈和队列
  • Linux shell编程学习笔记11:关系运算
  • JS标准库
  • Android 12.0 hal层添加自定义hal模块功能实现
  • 如何理解vue声明式渲染
  • 【已解决】Vue全局引入scss 个别页面不生效 / 不自动引入全局样式