八皇后 递归or迭代
Posted 给杰瑞一块奶酪~
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了八皇后 递归or迭代相关的知识,希望对你有一定的参考价值。
递归:
#include <iostream> #include <cstdlib> #include <cstdio> using namespace std; int que[8]={0},cc=0; void print() { cc++; cout<<cc<<‘:‘; for(int i=0;i<=7;i++) cout<<que[i]<<‘ ‘; cout<<endl; } int check(int c) { if(que[c]>8)return 0; for(int i=0;i<c;i++) { if(que[i]==que[c]||que[i]-que[c]==i-c||que[i]-que[c]==c-i)return 0; } return 1; } void queue8(int i) { if(i==8){print();return;} for(int j=1;j<=8;j++) { que[i]=j; if(check(i))queue8(i+1); } } int main() { queue8(0); }
迭代:
#include <iostream> #include <cstdlib> #include <cstdio> using namespace std; int que[8]={0},c,count; void print() { c++; cout<<c<<‘:‘; for(int i=0;i<=7;i++) cout<<que[i]<<‘ ‘; cout<<endl; } int check(int c) { if(que[c]>8)return 0; for(int i=0;i<c;i++) { if(que[i]==que[c]||que[i]-que[c]==i-c||que[i]-que[c]==c-i)return 0; } return 1; } void queue8() { int cc=0; while(count>=0&&count<=7) { que[count]++; if(check(count)) { count++; } else if(que[count]>8)que[count]=0,count--; if(count>7){print();count--;} } } int main() { queue8(); }
以上是关于八皇后 递归or迭代的主要内容,如果未能解决你的问题,请参考以下文章