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

一、共同点:

二、区别:

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

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

三、例题:

题目

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


一、共同点:

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

//key指数组下标,count指该下标对应的值。相当于int a[i]=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;
}
相关推荐
Narrastory2 小时前
Note:强化学习(一)
人工智能·算法·强化学习
沐雪轻挽萤3 小时前
1. C++17新特性-序章
java·c++·算法
郝学胜-神的一滴3 小时前
从链表到二叉树:树形结构的入门与核心性质解析
数据结构·c++·python·算法·链表
csdn_aspnet3 小时前
C语言 (QuickSort using Random Pivoting)使用随机枢轴的快速排序
c语言·算法·排序算法
玖釉-3 小时前
深入解析 meshoptimizer:基于 meshopt_computeSphereBounds 的层级包围球构建与 DAG 优化
c++·算法·图形渲染
CoderMeijun3 小时前
C++ 单例模式:饿汉模式与懒汉模式
c++·单例模式·设计模式·饿汉模式·懒汉模式
电商API&Tina3 小时前
淘宝 / 京东关键词搜索 API 接入与实战用途教程|从 0 到 1 搭建电商选品 / 比价 / 爬虫替代系统
java·开发语言·数据库·c++·python·spring
语戚3 小时前
力扣 494. 目标和 —— 回溯 & 动态规划双解法全解(Java 实现)
java·算法·leetcode·动态规划·力扣·dp·回溯
初圣魔门首席弟子3 小时前
Doxygen 文档注释详细介绍(含实际案例)
c++