題目描述 description
yours和zero在研究a*啟發式演算法.拿到一道經典的a*問題,但是他們不會做,請你幫他們.
問題描述
在3×3的棋盤上,擺有八個棋子,每個棋子上標有1至8的某一數字。棋盤中留有乙個空格,空格用0來表示。空格周圍的棋子可以移到空格中。要求解的問題是:給出一種初始布局(初始狀態)和目標布局(為了使題目簡單,設目標狀態為123804765),找到一種最少步驟的移動方法,實現從初始布局到目標布局的轉變。
輸入描述 input description
輸入初試狀態,一行九個數字,空格用0表示
輸出描述 output description
只有一行,該行只有乙個數字,表示從初始狀態到目標狀態需要的最少移動次數(測試資料中無特殊無法到達目標狀態資料)
樣例輸入 sample input
283104765
樣例輸出 sample output
4不加a*也能過,加了跑得賊快
**bfs,優先取出f[i]較小的點
f[i] = g[i] +h[i],其中g[i]為已走步數,h[i]為不在位的數碼個數
#include
#include
#include
#include
using
namespace
std;
const
int maxn = 15;
int ss = ;
const
int m_s = 100000009;
struct zt
;bool
operator
< (zt a,zt b)
int f(zt x)
priority_queue q;
char c[15];
int mu = ;
zt x;
bool hash[m_s + 1];
bool can(zt u)
if(hash[ans])return
false;
hash[ans] = true;
return
true;
}int main()
x.f = f(x);
q.push(x);
while(!q.empty())}}
return
0; }
CodeVs 1225 八數碼難題
yours和zero在研究a 啟發式演算法.拿到一道經典的a 問題,但是他們不會做,請你幫他們.問題描述 在3 3的棋盤上,擺有八個棋子,每個棋子上標有1至8的某一數字。棋盤中留有乙個空格,空格用0來表示。空格周圍的棋子可以移到空格中。要求解的問題是 給出一種初始布局 初始狀態 和目標布局 為了使題...
codevs 1225 八數碼難題 題解
yours和zero在研究a 啟發式演算法.拿到一道經典的a 問題,但是他們不會做,請你幫他們.問題描述 在3 3的棋盤上,擺有八個棋子,每個棋子上標有1至8的某一數字。棋盤中留有乙個空格,空格用0來表示。空格周圍的棋子可以移到空格中。要求解的問題是 給出一種初始布局 初始狀態 和目標布局 為了使題...
codevs1225八數碼難題(搜尋 )
時間限制 1 s 空間限制 128000 kb 題目等級 鑽石 diamond 題解yours和zero在研究a 啟發式演算法.拿到一道經典的a 問題,但是他們不會做,請你幫他們.問題描述 在3 3的棋盤上,擺有八個棋子,每個棋子上標有1至8的某一數字。棋盤中留有乙個空格,空格用0來表示。空格周圍的...