日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

codevs 1004 四子连棋 BFS、hash判重

發布時間:2025/3/13 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 codevs 1004 四子连棋 BFS、hash判重 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

004 四子連棋

?

時間限制: 1 s 空間限制: 128000 KB 題目等級 : 黃金 Gold 題目描述 Description

在一個4*4的棋盤上擺放了14顆棋子,其中有7顆白色棋子,7顆黑色棋子,有兩個空白地帶,任何一顆黑白棋子都可以向上下左右四個方向移動到相鄰的空格,這叫行棋一步,黑白雙方交替走棋,任意一方可以先走,如果某個時刻使得任意一種顏色的棋子形成四個一線(包括斜線),這樣的狀態為目標棋局。

?
?

?

輸入描述 Input Description 從文件中讀入一個4*4的初始棋局,黑棋子用B表示,白棋子用W表示,空格地帶用O表示。 輸出描述 Output Description

用最少的步數移動到目標棋局的步數。

樣例輸入 Sample Input

BWBO
WBWB
BWBW
WBWO

樣例輸出 Sample Output

5

數據范圍及提示 Data Size & Hint

hi

#include<iostream> using namespace std; struct data{int mp[5][5];//1白棋,2黑棋,0空格 }d[5000]; int next[5000]={1,2};//下一步走黑棋還是白棋,1為白,2為黑 int step[5000]; bool hash[4000000]; int xx[4]={0,0,1,-1},yy[4]={1,-1,0,0}; int t=0,w=2,flag=0; bool equ(int a1,int a2,int a3,int a4){if(a1!=a2||a2!=a3||a3!=a4||a4!=a1)return 0;return 1;} bool check(){for(int i=1;i<=4;i++){if(equ(d[w].mp[i][1],d[w].mp[i][2],d[w].mp[i][3],d[w].mp[i][4]))return 1;if(equ(d[w].mp[1][i],d[w].mp[2][i],d[w].mp[3][i],d[w].mp[4][i]))return 1;}if(equ(d[w].mp[1][1],d[w].mp[2][2],d[w].mp[3][3],d[w].mp[4][4]))return 1;if(equ(d[w].mp[1][4],d[w].mp[2][3],d[w].mp[3][2],d[w].mp[4][1]))return 1;return 0; } int Hash(){//哈希判重 int s=0,k=1;for(int i=1;i<=4;i++)for(int j=1;j<=4;j++){s+=d[w].mp[i][j]*k;k*=3;}s%=3733799;if(!hash[s]){hash[s]=1;return 1;}return 0; } bool pd(int x,int y){int k=next[t];if(x>4||y>4||x==0||y==0)return 0;else if(d[t].mp[x][y]==k)return 1;return 0; } void sp(int &a,int &b){int t=a;a=b;b=t;} void move(int x,int y){for(int i=0;i<4;i++){int p=x+xx[i],q=y+yy[i];if(pd(p,q)){for(int j=1;j<=4;j++)for(int k=1;k<=4;k++)d[w].mp[j][k]=d[t].mp[j][k];sp(d[w].mp[x][y],d[w].mp[p][q]);step[w]=step[t]+1;if(check()){cout<<step[w];flag=1;return;}if(Hash()){ if(next[t]==1)next[w++]=2;if(next[t]==2)next[w++]=1;}}} } void search(){while(t<w){for(int i=1;i<=4;i++)for(int j=1;j<=4;j++){if(d[t].mp[i][j]==0)move(i,j);if(flag)return;}t++;} } int main(){char x;for(int i=1;i<=4;i++)for(int j=1;j<=4;j++){cin>>x;if(x=='W')d[0].mp[i][j]=d[1].mp[i][j]=1;else if(x=='B')d[0].mp[i][j]=d[1].mp[i][j]=2;}search();return 0; }

?

轉載于:https://www.cnblogs.com/qscqesze/p/4227210.html

總結

以上是生活随笔為你收集整理的codevs 1004 四子连棋 BFS、hash判重的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。