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;
}
相关推荐
月光刺眼4 分钟前
🎶二分 · 双指针 · 滑动窗口 · 螺旋矩阵:数组算法四题拆解
javascript·算法
星卯教育tony7 分钟前
CIE中国电子学会2026年3月c++ Python scratch 机器人真题试卷含参考答案
c++·python·scratch·电子学会
海清河晏11110 分钟前
字符串匹配:BF算法与KMP算法
数据结构·算法·visual studio
wandertp18 分钟前
对信号处理及滤波器的理解---基于robomaster机器人嵌入式控制系统
arm开发·stm32·算法·信号处理
z小猫不吃鱼23 分钟前
15 InstructGPT 论文精读:SFT + RLHF 如何让模型听懂指令?
人工智能·深度学习·算法·机器学习·语言模型·自然语言处理·gpt-3
见合八方33 分钟前
【滤波器】热调谐FP滤波器
人工智能·算法
古城小栈34 分钟前
cargo-pprof:Rust性能调优
人工智能·算法·rust
x_xbx44 分钟前
LeetCode:543. 二叉树的直径
算法·leetcode·职场和发展
汉克老师44 分钟前
GESP6级C++考试语法知识(三十九、动态规划的启蒙(四、二维DP))
c++·动态规划·dp·gesp六级·二维dp
QiLinkOS1 小时前
QiLink 技术委员会选举实施细则
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源