BFS/BFS模板

 

DFS:

#include<bits/stdc++.h>   
using namespace std;   
#define max 100  
bool vis[max][max];   
int mp[max][max];   
int dir[4][2]={-1,0,0,1,1,0,0,-1};   
void dfs(int x,int y) {   
    vis[x][y]=1;   
    if(mp[x][y]==G) {  
     ...... return;   
     }   
     for(int i=0;i<4;i++) {   
        if())   
        dfs(x+dir[i][0],y+dir[i][1]);   
                vis[][]=0;   
    }  
     return;  
}   
int main() { ......   
     if( )  
    dfs();  
    vis[][]=0; return 0;      
}  
BFS:
#include<bits/stdc++.h>   
using namespace std;   
#definemaxn 100   
bool vis[max][max];   
int dir[4][2]={-1,0,0,1,1,0,0,-1}; //(具体情况设置)   
struct state{   
    int x,y;   
    int step;   
}a;   
queue<State>q;   
bool check(state s){   
    if(...) return 1;   
    else return 0;   
}   
void bfs(state st){  
    state now,next;   
     st.step=0;   
     q.push(st);   
     vis[st.x][st.y]=1;   
    while(!q.empty()){   
    now=q.front();   
    if(now==最终状态){  
     ...... return; }  
      for(int i=0;i<4;i++){  
        next.x=now.x+dir[i][0];   
        next.y=now.y+dir[i][1];   
        next.stepr=now.step+1;   
        if(check(next)){   
        q.push(next);   
        vis[next.x][next.y]=1;   
        }   
      }   
    q.pop();   
    }   
}

 

 

### C++ 实现的 BFS 广度优先搜索算法 以下是使用 C++ 编写的广度优先搜索 (BFS) 算法模板代码。此代码适用于无权图中的路径查找问题。 ```cpp #include <iostream> #include <vector> #include <queue> using namespace std; void bfs(int start, const vector<vector<int>> &adjList, int n) { vector<bool> visited(n, false); // 记录节点访问状态 queue<int> q; // 队列用于存储待访问的节点 q.push(start); visited[start] = true; while (!q.empty()) { // 当队列不为空时继续遍历 int current = q.front(); // 获取当前节点 q.pop(); cout << "Visited node: " << current << endl; // 处理当前节点 for (int neighbor : adjList[current]) { // 遍历相邻节点 if (!visited[neighbor]) { // 如果未被访问过,则加入队列并标记为已访问 q.push(neighbor); visited[neighbor] = true; } } } } int main() { int n = 6; // 节点数量 vector<vector<int>> adjList = { // 邻接表表示图 {1, 2}, // 节点0连接到节点1和节点2 {0, 3, 4}, // 节点1连接到节点0、3和4 {0, 5}, // 节点2连接到节点0和5 {1}, // 节点3连接到节点1 {1}, // 节点4连接到节点1 {2} // 节点5连接到节点2 }; bfs(0, adjList, n); // 从节点0开始执行BFS return 0; } ``` 上述代码实现了基本的广度优先搜索功能,其中邻接表 `adjList` 表示图的数据结构[^1]。通过维护一个布尔数组 `visited[]` 来记录哪些节点已经被访问过,防止重复访问同一节点。利用队列 `queue<>` 存储即将访问的节点,并按层次顺序依次扩展邻居节点[^2]。 #### 关键特性说明 - **初始化**:将起点放入队列中,并将其标记为已访问。 - **循环条件**:当队列非空时持续运行。 - **节点处理**:每次取出队首元素作为当前节点进行操作(此处简单打印),随后检查其所有邻居节点是否已被访问;如果未访问则入队并更新状态。 这种实现方式特别适合解决连通性和最短距离等问题,在实际应用中有广泛用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值