搜索和图论_复习
DFS
AcWing 842. 排列数字
代码
#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int> PII;
const int N=10;
int path[N];
bool st[N];
int n;
void dfs(int x){
if(x>n) return ;
for(int i=1;i<=n;i++){
if(st[i]==1) continue;
st[i]=1;
path[x]=i;
dfs(x+1);
st[i]=0;
}
if(x==n){
for(int i=1;i<=n;i++)
if(i==n)cout<<path[i]<<endl;
else cout<<path[i]<<" ";
}
}
int main(){
cin>>n;
dfs(1);
return 0;
}
843. n-皇后问题
代码
#include <iostream>
using namespace std;
const int N = 10;
int n;
bool row[N], col[N], dg[N * 2], udg[N * 2];
char g[N][N];
void dfs(int x, int y, int s)
{
if (s > n) return;
if (y == n) y = 0, x ++ ;
if (x == n)
{
if (s == n)
{
for (int i = 0; i < n; i ++ ) puts(g[i]);
puts("");
}
return;
}
g[x][y] = '.';
//不放皇后
dfs(x, y + 1, s);
//放皇后
if (!row[x] && !col[y] && !dg[x + y] && !udg[x - y + n])
{
row[x] = col[y] = dg[x + y] = udg[x - y + n] = true;
g[x][y] = 'Q';
dfs(x, y + 1, s + 1);
g[x][y] = '.';
row[x] = col[y] = dg[x + y] = udg[x - y + n] = false;
}
}
int main()
{
cin >> n;
dfs(0, 0, 0);
return 0;
}
第二种搜索顺序
#include <iostream>
using namespace std;
const int N = 20;
int n;
char g[N][N];
bool col[N], dg[N], udg[N];
void dfs(int u)
{
if (u == n)
{
for (int i = 0; i < n; i ++ ) puts(g[i]);
puts("");
return;
}
for (int i = 0; i < n; i ++ )
if (!col[i] && !dg[u + i] && !udg[n - u + i])
{
g[u][i] = 'Q';
col[i] = dg[u + i] = udg[n - u + i] = true;
dfs(u + 1);
col[i] = dg[u + i] = udg[n - u + i] = false;
g[u][i] = '.';
}
}
int main()
{
cin >> n;
for (int i = 0; i < n; i ++ )
for (int j = 0; j < n; j ++ )
g[i][j] = '.';
dfs(0);
return 0;
}
BFS
bfs一层一层的搜,因此可以找到最短路
844. 走迷宫
#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int> PII;
const int N=111;
int n,m;
int g[N][N], d[N][N];
int bfs(){
queue<PII> q;
q.push({0,0});
memset(d,-1,sizeof d);
d[0][0]=0;
int dx[]={0,0,1,-1};
int dy[]={1,-1,0,0};
while(q.size()){
PII t=q.front();
q.pop();
for (int i=0;i<4;i++)
{
int x=t.first+dx[i], y=t.second+dy[i];
if (x >= 0 && x < n && y >= 0 && y < m && g[x][y] == 0 && d[x][y] == -1)
{
d[x][y]=d[t.first][t.second]+1;
q.push({x, y});
}
}
}
return d[n-1][m-1];
}
int main(){
cin>>n>>m;
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
cin>>g[i][j];
}
}
cout<<bfs()<<endl;
return 0;
}
链式前向星
int h[N], to[N], pre[M], idx;
void add(int a, int b)
{
to[idx] = b, pre[idx] = h[a], h[a] = idx++;
}
signed main()
{
memset(head, -1, sizeof(head));
return 0;
}