蓝桥集训之格子游戏

蓝桥集训之格子游戏

  • 核心思想:并查集

    • 将二维坐标转化为一维坐标 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;
  }
相关推荐
IT大白鼠1 小时前
AIGC性能的关键瓶颈:算力、数据、算法三者如何互相制约?
算法·aigc
tjl521314_211 小时前
04C++ 名称空间(Namespace)
开发语言·c++
ximu_polaris1 小时前
设计模式(C++)-行为型模式-备忘录模式
c++·设计模式·备忘录模式
白雪茫茫2 小时前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky2 小时前
浅析 空间频率响应 SFR 计算
算法
树下水月2 小时前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集3 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考4 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
刀法如飞5 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
tankeven6 小时前
C++ 智能指针
c++