P2580 于是他错误的点名开始了 题解
“普及/提高-”这个难度很有意思。
说明这题可能需要用到提高组当中比较基础的内容。
它的名字叫做 map。
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
#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;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具