不相交集类应用:迷宫生成

简介:
复制代码
  1 #include <iostream>
  2 #include <vector>
  3 #include <cstdlib>
  4 #include <ctime>
  5 
  6 #define N 100
  7 
  8 using namespace std;
  9 
 10 int wall_row[N+1][N];
 11 int wall_col[N][N+1];
 12 
 13 class DisjSets
 14 {
 15 public:
 16   explicit DisjSets(int numElements);
 17 
 18   int find(int x) const;
 19   void unionSets(int node1, int node2);
 20   bool connected(int node1, int node2) const
 21   {
 22     return find(node1) == find(node2);
 23   }
 24 
 25 private:
 26   vector<int> s;
 27 };
 28 
 29 DisjSets::DisjSets(int numElements):s(numElements)
 30 {
 31   for (int i = 0; i < s.size(); i++)
 32     s[i] = -1;
 33 }
 34 
 35 int DisjSets::find(int x) const
 36 {
 37   if (s[x] < 0)
 38     return x;
 39   else
 40     return find(s[x]);
 41 }
 42 
 43 void DisjSets::unionSets(int node1, int node2)
 44 {
 45   int root1 = find(node1);
 46   int root2= find(node2);
 47 
 48   if (root1==root2)
 49     return;
 50 
 51   if (s[root2] < s[root1])
 52     s[root1] = root2;
 53   else 
 54   {
 55     if(s[root1] == s[root2])
 56       s[root1]--;
 57     s[root2] = root1;
 58   }
 59 }
 60 
 61 void fill(int value)
 62 {
 63   int i,j;
 64   for(i=0; i<N+1; i++)
 65     for(j=0; j<N; j++)
 66       wall_row[i][j] = value;
 67   for(i=0; i<N; i++)
 68     for(j=0; j<N+1; j++)
 69       wall_col[i][j] = value;
 70 }
 71 
 72 void print()
 73 {
 74   int i, j;
 75   for (i=0; i<N+1; i++) 
 76   {
 77     for (j=0; j<N+1; j++) 
 78     {
 79         if (i > 0)
 80         {
 81             if(wall_col[i-1][j])
 82               cout<<"|";
 83             else
 84               cout<<" ";
 85         }
 86         if (j<N)
 87         {
 88             if (i>0)
 89             {
 90               if (wall_row[i][j])
 91                 cout<<"_";
 92               else
 93                 cout<<" ";
 94             }
 95             else
 96             {
 97               if(wall_row[i][j])
 98                 cout<<" _";
 99               else
100                 cout<<"  ";
101             }
102         }
103     }
104     cout<<endl;
105   }
106 }
107 
108 void map_rand(int x, int &type, int &a, int &b)
109 {
110   type = 0;
111   if(x >= N*(N-1)) 
112       type = 1;
113   if(type == 0) 
114   {
115     a = x / (N - 1);
116     b = x % (N - 1) + 1;
117   } 
118   else 
119   {
120     x -= N*(N-1);
121     a = x / N + 1;
122     b = x % N;
123   }
124 }
125 
126 void map_pos(int type, int a, int b, int &node1, int &node2)
127 {
128   if(type == 0) 
129   {
130     node1 = a * N + b - 1;
131     node2 = a * N + b;
132   } else 
133   {
134     node1 = (a - 1) * N + b;
135     node2 = (a - 1) * N + b + N;
136   }
137 }
138 
139 int randselect(void)
140 {
141   int range = N*(N-1)*2;
142   return rand() % range;
143 }
144 
145 int main()
146 {
147   fill(1); //赋值全部为1
148   srand(time(0));
149   wall_row[0][0] = 0;
150   wall_col[0][0] = 0;
151   wall_row[N][N-1] = 0;
152   wall_col[N-1][N] = 0;//定义出口入口
153 
154   int amount = N * N;
155 
156   DisjSets s(amount);
157 
158   while(!s.connected(0, amount-1)) //是否两个节点相连(相同)
159   {
160     int type, a, b;
161     do 
162     {
163       int wall = randselect();
164       map_rand(wall, type, a, b);
165     } 
166     while ((type == 0 && wall_col[a][b] == 0) ||(type == 1 && wall_row[a][b] == 0))
167         ;
168     int node1, node2;
169     map_pos(type, a, b, node1, node2);
170     if(!s.connected(node1, node2)) 
171     {
172       if(type == 0)
173         wall_col[a][b] = 0;
174       else
175         wall_row[a][b] = 0;
176       s.unionSets(node1, node2);
177     }
178   }
179   print();
180   return 0;
181 }
复制代码

生成结果“

本文转自博客园xingoo的博客,原文链接:不相交集类应用:迷宫生成,如需转载请自行联系原博主。
相关文章
|
11天前
|
人工智能 自然语言处理 监控
OpenClaw skills重构量化交易逻辑:部署+AI全自动炒股指南(2026终极版)
2026年,AI Agent领域最震撼的突破来自OpenClaw(原Clawdbot)——这个能自主规划、执行任务的智能体,用50美元启动资金创造了48小时滚雪球至2980美元的奇迹,收益率高达5860%。其核心逻辑堪称教科书级:每10分钟扫描Polymarket近千个预测市场,借助Claude API深度推理,交叉验证NOAA天气数据、体育伤病报告、加密货币链上情绪等多维度信息,捕捉8%以上的定价偏差,再通过凯利准则将单仓位严格控制在总资金6%以内,实现低风险高频套利。
5014 43
|
28天前
|
人工智能 自然语言处理 Shell
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
本教程指导用户在开源AI助手Clawdbot中集成阿里云百炼API,涵盖安装Clawdbot、获取百炼API Key、配置环境变量与模型参数、验证调用等完整流程,支持Qwen3-max thinking (Qwen3-Max-2026-01-23)/Qwen - Plus等主流模型,助力本地化智能自动化。
38634 151
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
|
6天前
|
存储 人工智能 负载均衡
阿里云OpenClaw多Agent实战宝典:从极速部署到AI团队搭建,一个人=一支高效军团
在AI自动化时代,单一Agent的“全能模式”早已无法满足复杂任务需求——记忆臃肿导致响应迟缓、上下文污染引发逻辑冲突、无关信息加载造成Token浪费,这些痛点让OpenClaw的潜力大打折扣。而多Agent架构的出现,彻底改变了这一现状:通过“单Gateway+多分身”模式,让一个Bot在不同场景下切换独立“大脑”,如同组建一支分工明确的AI团队,实现创意、写作、编码、数据分析等任务的高效协同。
1637 24
|
3天前
|
人工智能 JavaScript API
2026年Windows系统本地部署OpenClaw指南:附阿里云简易部署OpenClaw方案,零技术基础也能玩转AI助手
在AI办公自动化全面普及的2026年,OpenClaw(原Clawdbot、Moltbot)凭借“自然语言指令操控、多任务自动化执行、多工具无缝集成”的核心优势,成为个人与轻量办公群体打造专属AI助手的首选。它彻底打破了传统AI“只会对话不会执行”的局限——“手”可读写本地文件、执行代码、操控命令行,“脚”能联网搜索、访问网页并分析内容,“大脑”则可灵活接入通义千问、OpenAI等云端API,或利用本地GPU运行模型,真正实现“聊天框里办大事”。
707 1
|
5天前
|
人工智能 自然语言处理 安全
2026年OpenClaw Skills安装指南:Top20必装清单+阿里云上部署实操(附代码命令)
OpenClaw(原Clawdbot)的强大之处,不仅在于其开源免费的AI执行引擎核心,更在于其庞大的Skills生态——截至2026年2月,官方技能市场ClawHub已收录1700+各类技能插件,覆盖办公自动化、智能交互、生活服务等全场景。但对新手而言,面对海量技能往往无从下手,盲目安装不仅导致功能冗余,还可能引发权限冲突与安全风险。
880 6
|
24天前
|
人工智能 安全 机器人
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
OpenClaw(原Clawdbot)是一款开源本地AI助手,支持钉钉、飞书等多平台接入。本教程手把手指导Linux下部署与钉钉机器人对接,涵盖环境配置、模型选择(如Qwen)、权限设置及调试,助你快速打造私有、安全、高权限的专属AI助理。(239字)
8788 24
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
|
5天前
|
人工智能 自然语言处理 安全
2026年OpenClaw(Clawdbot)效率翻倍指南:部署+10个必备Skills,解锁AI生产力
很多用户部署OpenClaw(Clawdbot)后都会陷入“看似强大却不好用”的困境,核心原因在于没有搭配合适的Skills(技能插件)。OpenClaw本体就像一台高性能电脑,而Skills如同各类专业软件,只有装上必备技能,才能真正发挥其自动化办公、开发辅助、内容创作等全场景能力。
927 6