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

目录

  • [1 知识点](#1 知识点)
  • [2 模板](#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 模板

cpp 复制代码
//输入是向量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个下标,题目中保证一定存在x
	int 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;
}

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

cpp 复制代码
//输入是向量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开始编号。
}
相关推荐
im_AMBER几秒前
Leetcode 113 合并 K 个升序链表
数据结构·学习·算法·leetcode·链表
高洁013 分钟前
基于物理交互的具身智能决策框架设计
算法·机器学习·数据挖掘·transformer·知识图谱
REDcker4 分钟前
TCP 拥塞控制算法详解:CUBIC、BBR 及传统算法
tcp/ip·算法·php
偷吃的耗子18 分钟前
[CNN算法理解]:二、卷积层(从生活实例到技术细节)
算法·cnn·生活
2301_7903009619 分钟前
C++与Docker集成开发
开发语言·c++·算法
TracyCoder12319 分钟前
LeetCode Hot100(22/100)——141. 环形链表
算法·leetcode·链表
一起养小猫24 分钟前
Flutter for OpenHarmony 进阶:递归算法与数学证明深度解析
算法·flutter
赛博云推-Twitter热门霸屏工具24 分钟前
Twitter 搜索霸屏的关键词工程方法——从算法理解到赛博云推的系统化执行
算法·twitter·dreamweaver
罗湖老棍子37 分钟前
【区间DP】括号序列:如何求解最长合法子序列?(POJ 2955)
算法·动态规划·区间dp·区间动态规划·端点匹配型
王德博客41 分钟前
【实现常见排序算法】直接插入排序的算法思想
数据结构·算法·排序算法