P2580 于是他错误的点名开始了 题解

P2580 于是他错误的点名开始了 题解

Leo2011 警示后人

“普及 / 提高 -” 这个难度很有意思。

说明这题可能需要用到提高组当中比较基础的内容。

它的名字叫做 map。


1
2
3
4
map<int, int> a;
a[7] = 5;
map<string, int> score;
score["Leo2011"] = 400;

map,其实相当于一个超大数组,但它真实的作用是:映射。比如 a[7] = 5; 就是用 a 数组把 7 和 5 关联了起来,这个操作就叫映射。

map 这东西 NB 的地方在于,它能这么写:score["Leo2011"] = 400;。哎对,这个类似下标的玩意儿就是个字符串!

有了这不好办了?拿这玩意儿记录一下有没有,然后分类判断即可。


ACCode:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#include <bits/stdc++.h>

using namespace std;

unordered_map<string, int> mp; // map会自动排序,此时访问时间复杂度为O(logn),unordered_map不排序,时间复杂度O(1)
int m, n;
string s;

int main() {
scanf("%d", &n);
for (int i = 1;i <= n;i++) {
cin >> s;
mp[s] = 1;
}
scanf("%d", &m);
for (int i = 1;i <= m;i++) {
cin >> s;
if (mp[s] == 1) {
printf("OK\n");
mp[s] = 2;
}
else
if (!mp[s])
printf("WRONG\n");
else
printf("REPEAT\n");
}
return 0;
}

AC 记录

  • 标题: P2580 于是他错误的点名开始了 题解
  • 作者: Leo2011
  • 创建于 : 2024-01-18 22:01:38
  • 更新于 : 2025-06-01 17:08:10
  • 链接: https://www.leo2011.eu.org/2024/01/18/p2580-yu-shi-ta-cuo-wu-de-dian-ming-kai-shi-liao-ti-jie/
  • 版权声明: 本文章采用 CC BY-NC-SA 4.0 进行许可。
评论
Nickname
Email
Website
  • OωO
  • |´・ω・) ノ
  • ヾ (≧∇≦*) ゝ
  • (☆ω☆)
  • (╯‵□′)╯︵┴─┴
  •  ̄﹃ ̄
  • (/ω\)
  • ∠( ᐛ 」∠)_
  • (๑•̀ㅁ•́ฅ)
  • →_→
  • ୧(๑•̀⌄•́๑)૭
  • ٩(ˊᗜˋ*)و
  • (ノ °ο°) ノ
  • (´இ皿இ`)
  • ⌇●﹏●⌇
  • (ฅ´ω`ฅ)
  • (╯°A°)╯︵○○○
  • φ( ̄∇ ̄o)
  • ヾ (´・ ・`。) ノ "
  • (ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
  • (ó﹏ò。)
  • Σ(っ °Д °;) っ
  • (,,´・ω・)ノ"(´ っ ω・`。)
  • ╮(╯▽╰)╭
  • o(*////▽////*)q
  • >﹏<
  • ( ๑´•ω•) "(ㆆᴗㆆ)
  • 😂
  • 😀
  • 😅
  • 😊
  • 🙂
  • 🙃
  • 😌
  • 😍
  • 😘
  • 😜
  • 😝
  • 😏
  • 😒
  • 🙄
  • 😳
  • 😡
  • 😔
  • 😫
  • 😱
  • 😭
  • 💩
  • 👻
  • 🙌
  • 🖕
  • 👍
  • 👫
  • 👬
  • 👭
  • 🌚
  • 🌝
  • 🙈
  • 💊
  • 😶
  • 🙏
  • 🍦
  • 🍉
  • 😣
  • 颜文字
  • Emoji
  • Bilibili
0 comments
No comment