鱼C论坛

 找回密码
 立即注册
查看: 1740|回复: 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:21:32 | 显示全部楼层
抱歉,这里没有提供任何问题或上下文信息。请提供更多详细信息,以便我可以为您提供帮助。谢谢!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-5 18:21:58 | 显示全部楼层
很高兴听到您的代码通过了样例测试。如果您有任何问题或报告漏洞,则可以参考以下建议:

1.阅读题目并确定边界条件:在提交您的代码之前,请确保您已经仔细阅读并理解了题目要求和边界条件。这有助于你在写代码时更加谨慎,减少代码漏洞的产生。

2.调试您的代码:如果您遇到了错误,请不要放弃。相反,您应该利用调试工具来查找和修复代码中的错误。在进行调试时,可以输出打印语句以查看变量值和执行路径等信息。

3.与其他人交流:您可以尝试与其他程序员交流,例如,让他们审查您的代码并提供建议。这样做有助于发现您可能忽略的问题,并且可以提高代码质量。

4.使用一些工程实践:您可以采用一些工程实践来提高代码的可维护性和可扩展性。例如,您可以使用命名变量、编写注释、编写单元测试等方法。这些技术都能够确保您的代码更加健壮,易于维护,并且可以提高代码的运行效率。

希望这些建议能对您有所帮助。祝你好运!

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-5 18:26:27 | 显示全部楼层
您的代码逻辑看起来是正确的,但是在处理 "start" 操作时,您需要确保在开始新一轮比赛之前清空队列。这是因为在新一轮比赛开始时,所有之前的选手都应该重新加入队列。为了解决这个问题,您可以在 "start" 操作的开始处清空队列。以下是修改后的代码:

  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.             // 清空队列
  21.             while (!q.empty()) {
  22.                 q.pop();
  23.             }

  24.             for(int j=0;j<playing_len;j++)
  25.             {
  26.                 q.push(playing[j]);
  27.             }
  28.             playing_len=0;
  29.             while(playing_len<2 and !q.empty())
  30.             {
  31.                 if(m.find(q.front())==m.end())// element doesn't exist
  32.                 {
  33.                     q.pop();
  34.                     continue;
  35.                 }
  36.                 playing[playing_len]=q.front();
  37.                 cout<<q.front()<<' ';
  38.                 playing_len++;
  39.                 q.pop();
  40.             }
  41.             if(playing_len==0)
  42.             {
  43.                 cout<<"Error\n";
  44.             }
  45.             else
  46.             {
  47.                 cout<<endl;
  48.             }
  49.         }
  50.         else if(op=="arrive")
  51.         {
  52.             cin>>str;
  53.             if(m.find(str)!=m.end())
  54.             {
  55.                 cout<<"Error\n";
  56.             }
  57.             else
  58.             {
  59.                 m[str]=true;
  60.                 q.push(str);
  61.                 cout<<"OK\n";
  62.             }
  63.         }
  64.         else// leave
  65.         {
  66.             cin>>str;
  67.             bool flag=false;
  68.             for(int i=0;i<playing_len;i++)
  69.             {
  70.                 if(playing[i]==str)
  71.                 {
  72.                     flag=true;
  73.                     break;
  74.                 }
  75.             }
复制代码


您的代码逻辑看起来是正确的,但是在处理 "start" 操作时,您需要确保在开始新一轮比赛之前清空队列。这是因为在新一轮比赛开始时,所有之前的选手都应该重新加入队列。为了解决这个问题,您可以在 "start" 操作的开始处清空队列。以下是修改后的代码:

  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.             // 清空队列
  21.             while (!q.empty()) {
  22.                 q.pop();
  23.             }

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


这个修改应该可以解决您遇到的问题。如果您在运行修改后的代码时仍然遇到问题,请随时告诉我。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-5 18:49:51 | 显示全部楼层
我蒟蒻
小甲鱼最新课程 -> 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:01:38 | 显示全部楼层
额外减小 发表于 2023-10-5 15:52
您?

刚刚学了dijkstra spfa,来这边扮猪吃老虎

确实蒟蒻我连个图的存储和遍历都搞不明白
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

好好好

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

使用道具 举报

发表于 2023-10-5 19:08:32 | 显示全部楼层
额外减小 发表于 2023-10-5 16:03
好好好

那你是怎么学这些算法的?

emmm
学完图的存储和dfs、bfs就学了啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-5 19:10:19 | 显示全部楼层
额外减小 发表于 2023-10-5 16:03
好好好

那你是怎么学这些算法的?

等学完最短路径就去刷题不过想必困难重重
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-22 05:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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