国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

P1219 N皇后(位運算&普通dfs)

2019-11-11 02:17:51
字體:
來源:轉載
供稿:網友

題見洛谷

位運算版(設計巧妙,需要回顧,加深理解)

#include<iostream>#include<cstdio>#include<cstring>#include<string>#include<algorithm>#include<vector>#include<queue>using namespace std;int a[20];int ans=0,uplimit,n;void PRint(){ for(int i=1;i<=n;i++) { int x=0;int y=a[i]; while(y) { y=y>>1; x++; } printf("%d ",x); } puts(""); }void dfs(int r,int ld,int rd){ if(r==uplimit){ ans++; if(ans<=3) print(); return; } int pos=uplimit & ~ (r|ld|rd); while(pos!=0) { int p=pos & (-pos);//pos=pos & (~pos+1); pos-=p; a[++a[0]]=p; dfs(r+p,(ld+p)<<1,(rd+p)>>1); a[a[0]]=0;a[0]--;//回溯 }}int main(){ scanf("%d",&n); uplimit=(1<<n)-1; dfs(0,0,0); printf("%d",ans); return 0;}

普通版

#include<iostream>#include<cstdio>#include<algorithm>#include<queue>#include<vector>#include<cstring>#include<string>#include<cmath>using namespace std;int n;int ans[100];int tot=0;int fa[100],fl[20],fb[100];void dfs(int k){ if(k>n){ if(tot<3){ for(int i=1;i<=n;i++) printf("%d ",ans[i]); printf("/n"); } tot++; } else { for(int i=1;i<=n;i++) if(fl[i]==0&&fa[i+k]==0&&fb[i-k+n]==0) { ans[k]=i; fl[i]=1; fa[i+k]=1; fb[i-k+n]=1; dfs(k+1); fl[i]=0; fa[i+k]=0; fb[i-k+n]=0; } }}int main(){ scanf("%d",&n); dfs(1); printf("%d",tot); return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沧州市| 称多县| 潼关县| 通许县| 忻城县| 龙江县| 淮阳县| 桐乡市| 古丈县| 嵩明县| 手游| 南漳县| 隆德县| 郎溪县| 惠东县| 义乌市| 崇仁县| 新化县| 古丈县| 东乡| 深圳市| 拉萨市| 红河县| 河南省| 永登县| 昌平区| 虹口区| 遵义市| 包头市| 鹤壁市| 苍南县| 高青县| 乳源| 衡东县| 文昌市| 灯塔市| 宜昌市| 施秉县| 屏东县| 无锡市| 宜黄县|