map<数据类型,数据类型> mp和unordered_map<数据类型,数据类型> ump的讲解,蓝桥杯OJ4567最大数目

一、共同点:

二、区别:

1.实现的逻辑【这个看看就行】:

2.算法比赛时候的选用:

三、例题:

题目

可执行代码:【①遍历map数组来找最大值②每次循环都提取出来最大值,循环结束后直接输出】


一、共同点:

map<数据类型,数据类型> mp和unordered_map<数据类型,数据类型> ump的定义方式和用法完全相同数组都是:mpkey=count;umpkey=count;

//key指数组下标,count指该下标对应的值。相当于int ai=7。key对应i,count对应7.

二、区别:

map<数据类型,数据类型> mp和unordered_map<数据类型,数据类型> ump的区别是:

1.实现的逻辑【这个看看就行】:

  • map:红黑树 → 有序,慢
  • unordered_map:哈希表 → 无序,快

2.算法比赛时候的选用:

  • 只需要统计次数、存映射、查有没有 → 用 unordered_map,更快不超时

  • 需要按 key 从小到大遍历、自动排序 → 只能用 map

  • 当n超过1e5的数据长度时只能用unordered_map

三、例题:

https://www.lanqiao.cn/problems/4567/learning/?page=1&first_category_id=1&name=%E6%9C%80%E5%A4%A7%E6%95%B0%E7%9B%AE&sort=problem_id&asc=1https://www.lanqiao.cn/problems/4567/learning/?page=1&first_category_id=1&name=%E6%9C%80%E5%A4%A7%E6%95%B0%E7%9B%AE&sort=problem_id&asc=1

题目:

可执行代码:【①遍历map数组来找最大值②每次循环都提取出来最大值,循环结束后直接输出】

cpp 复制代码
//①遍历map数组来找最大值
#include <bits/stdc++.h>
using namespace std;
long long n,m;
const int N=1e5+10;
long long a[N];
unordered_map<long long,long long> mp;
int main()
{
  cin>>n;
  for(int i=1;i<=n;i++) cin>>a[i];
  sort(a+1,a+1+n);
  for(int i=1;i<=n;i++){
    mp[a[i]+1]++;
    mp[a[i]]++;
    mp[a[i]-1]++;
  }
  for(auto it=mp.begin();it!=mp.end();it++){
     if(it->second>m) m=it->second;
  }
  cout<<m;
  return 0;
}



//②每次循环都提取出来最大值,循环结束后直接输出
#include <bits/stdc++.h>
using namespace std;
long long n,m;
const int N=1e5+10;
long long a[N];
unordered_map<long long,long long> mp;
int main()
{
  cin>>n;
  for(int i=1;i<=n;i++) cin>>a[i];
  sort(a+1,a+1+n);
  for(int i=1;i<=n;i++){
    mp[a[i]+1]++;
    mp[a[i]]++;
    mp[a[i]-1]++;
    m=max(m,mp[a[i]+1]);
    m=max(m,mp[a[i]]);
    m=max(m,mp[a[i]-1]);
  }
  cout<<m;
  return 0;
}
相关推荐
JieE21215 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint4563 天前
C++进阶(1)——前景提要
c++