蓝桥集训之格子游戏

蓝桥集训之格子游戏

  • 核心思想:并查集

    • 将二维坐标转化为一维坐标 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;
  }
相关推荐
过河卒_zh156676634 分钟前
9.13AI简报丨哈佛医学院开源AI模型,Genspark推出AI浏览器
人工智能·算法·microsoft·aigc·算法备案·生成合成类算法备案
D.....l40 分钟前
冒泡排序与选择排序以及单链表与双链表
数据结构·算法·排序算法
sinat_286945191 小时前
Case-Based Reasoning用于RAG
人工智能·算法·chatgpt
Athenaand1 小时前
代码随想录算法训练营第50天 | 图论理论基础、深搜理论基础、98. 所有可达路径、广搜理论基础
算法·图论
地平线开发者1 小时前
征程 6 灰度图部署链路介绍
人工智能·算法·自动驾驶·汽车
大白同学4211 小时前
【C++】C++11介绍(Ⅱ)
开发语言·c++
油炸自行车1 小时前
【Qt】编写Qt自定义Ui控件步骤
开发语言·c++·qt·ui·自定义ui控件·qt4 自定义ui控件
wanhengidc2 小时前
手机云服务是什么意思?
运维·网络·安全·游戏·智能手机