鱼C论坛

 找回密码
 立即注册
查看: 2389|回复: 10

p9518 用map做的,样例过,求调/hack

[复制链接]
发表于 2023-10-5 18:21:27 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
rt.


record

https://www.luogu.com.cn/record/127633464

思路就是用 map 记录一个元素是否存在,当队首元素不存在时弹出并跳过。

其他的就是纯模拟,但是看不出哪错了

code

  1. #include <iostream>
  2. #include <string>
  3. #include <queue>
  4. #include <map>
  5. using namespace std;

  6. int main()
  7. {
  8.         ios::sync_with_stdio(false);
  9.         cin.tie(0);
  10.         queue<string> q;
  11.         map<string,bool> m;
  12.         string str,op,playing[2];
  13.         int n,playing_len=0;
  14.         cin>>n;
  15.         for(int i=0;i<n;i++)
  16.         {
  17.                 cin>>op;
  18.                 if(op=="start")
  19.                 {
  20.                         for(int j=0;j<playing_len;j++)
  21.                         {
  22.                                 q.push(playing[j]);
  23.                         }
  24.                         playing_len=0;
  25.                         while(playing_len<2 and !q.empty())
  26.                         {
  27.                                 if(m.find(q.front())==m.end())// element doesn't exist
  28.                                 {
  29.                                         q.pop();
  30.                                         continue;
  31.                                 }
  32.                                 playing[playing_len]=q.front();
  33.                                 cout<<q.front()<<' ';
  34.                                 playing_len++;
  35.                                 q.pop();
  36.                         }
  37.                         if(playing_len==0)
  38.                         {
  39.                                 cout<<"Error\n";
  40.                         }
  41.             else
  42.             {
  43.                 cout<<endl;
  44.             }
  45.                 }
  46.                 else if(op=="arrive")
  47.                 {
  48.                         cin>>str;
  49.                         if(m.find(str)!=m.end())
  50.                         {
  51.                                 cout<<"Error\n";
  52.                         }
  53.                         else
  54.                         {
  55.                                 m[str]=true;
  56.                                 q.push(str);
  57.                                 cout<<"OK\n";
  58.                         }
  59.                 }
  60.                 else// leave
  61.                 {
  62.                         cin>>str;
  63.             bool flag=false;
  64.             for(int i=0;i<playing_len;i++)
  65.             {
  66.                 if(playing[i]==str)
  67.                 {
  68.                     flag=true;
  69.                     break;
  70.                 }
  71.             }
  72.                         if(m.find(str)==m.end() or flag)
  73.                         {
  74.                                 cout<<"Error\n";
  75.                         }
  76.                         else
  77.                         {
  78.                                 m.erase(m.find(str));
  79.                                 cout<<"OK\n";
  80.                         }
  81.                        
  82.                 }
  83.         }
  84. }
复制代码


@Ewan-Ahiouy @Mike_python小 @sfqxx
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-10-5 18:52:38 | 显示全部楼层

您?

刚刚学了dijkstra spfa,来这边扮猪吃老虎
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-10-5 18:53:08 | 显示全部楼层

你最好是(
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-10-5 19:03:38 | 显示全部楼层
Mike_python小 发表于 2023-10-5 19:01
确实蒟蒻我连个图的存储和遍历都搞不明白

好好好

那你是怎么学这些算法的?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-10-20 03:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表