打印了栈的大小,总觉得dfs不能直观的感受 ,
打印了一下变化的过程
#include <iostream>
#include <set>
#include <vector>
#include <map>
#include <stack>
#include <tuple>
#include <algorithm>
#include <iterator>
#include <unordered_set>
#include <windows.h>
#include <time.h>
#define debug(x) cout<<#x<<": "<<(x)<<endl;
using namespace std;
#define N (10)
int g[N][N];
int dx[4] = { 1,-1,0,0 };
int dy[4] = { 0,0,1,-1 };
stack<pair< int, int>>st;
bool print() {
Sleep(500);
system("cls");
for (int i = 0; i < N; ++i) {
for (int j = 0;j< N;++j) {
if (g[i][j] == 0) {
cout << "□";
}
else {
cout << "■";
}
}
cout << endl;
}
cout<<"stack size: "<< st.size()<< " " << string(st.size(), '#') << endl;;
return true;
}
bool ver(int x,int y){
if (x >= 0 && x < N && y >= 0 && y < N) {
return true;
}
return false;
}
bool dfs(int x,int y) {
print();
for (int i = 0; i < 4; ++i) {
if (ver(x + dx[i], y + dy[i]) && g[x + dx[i]][y+dy[i]] == 0) {
g[x + dx[i]][y + dy[i]] = 1;
dfs(x + dx[i], y + dy[i]);
}
}
return true;
}
int main() {
fill(g[0], g[0] + N*N, 0);
/*dfs(N/2,N/2);
return 0;*/
print();
st.push({ N/2,N/2 });
g[5][5] = 1;
while (!st.empty()) {
auto p = st.top();
//st.pop();
int x = p.first;
int y = p.second;
print();
int i = 0;
for (i = 0; i < 4; ++i) {
if (ver(x + dx[i], y + dy[i]) && g[x + dx[i]][y + dy[i]] == 0) {
g[x + dx[i]][y + dy[i]] = 1;
st.push({ x + dx[i], y + dy[i] });
break;
}
}
if (i == 4) {
st.pop();
}
}
return 0;
}