蓝桥集训之格子游戏

蓝桥集训之格子游戏

  • 核心思想:并查集

    • 将二维坐标转化为一维坐标 x*n+y
    • 每次将两个点合并 同时判断两点是否在同一集合内
    • 若在 则本次连接可以成环
cpp 复制代码
  #include<iostream>
  #include<cstring>
  
  using namespace std;
  const int N = 40010;  //原本的n 的平方
  
  int p[N];
  int n,m;
  
  int getxy(int x,int y)
  {
      return x*n + y;  //转化一维坐标
  }
  
  int find(int x)
  {
      if(p[x]!=x) p[x] = find(p[x]);
      return p[x];
  }
  
  int main()
  {
      cin>>n>>m;
      for(int i=0;i<n*n;i++) p[i] = i;  //最大n * n
      
      int res=0;
      for(int i=1;i<=m;i++)
      {
          int x,y;
          char d;
          cin>>x>>y>>d;
          x -- , y --;  //坐标从0开始才可以转化
          int a = getxy(x,y);
          int b;
          if(d == 'D') b = getxy(x+1,y);  //往下走 找下点的坐标
          else b = getxy(x,y+1);  //找右点的坐标
          
          int pa = find(a) , pb = find(b);
          if(pa == pb)  //本次成环
          {
              res = i;
              break;
          }
          else
          {
              p[pa] = pb;
          }
      }
      if(res == 0) puts("draw");
      else cout<<res;
  }
相关推荐
爱吃橘的橘猫几秒前
嵌入式系统与嵌入式 C 语言(2)
c语言·算法·嵌入式
235164 分钟前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
星夜钢琴手1 小时前
推荐的 Visual Studio 2026 Insider C++ 程序项目属性配置
c++·visual studio
ChivenZhang1 小时前
我对游戏后端的认识
后端·游戏
weixin_307779131 小时前
使用Python高效读取ZIP压缩文件中的UTF-8 JSON数据到Pandas和PySpark DataFrame
开发语言·python·算法·自动化·json
柳安忆1 小时前
【论文阅读】Sparks of Science
算法
2501_929382651 小时前
iphone IOS3~IOS9游戏 旧iphone 单机游戏合集分享
游戏·ios·iphone
web安全工具库2 小时前
从课堂笔记到实践:深入理解Linux C函数库的奥秘
java·数据库·算法
kyle~2 小时前
Qt---setAttribute设置控件或窗口的内部属性
服务器·前端·c++·qt
hsjkdhs3 小时前
C++之多态
开发语言·jvm·c++