1225 八數位難題

来源:http://www.cnblogs.com/zwfymqz/archive/2017/04/22/6749369.html
-Advertisement-
Play Games

1225 八數位難題 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 題解 查看運行結果 1225 八數位難題 1225 八數位難題 時間限制: 1 s 空間限制: 128000 KB 題目等級 : 鑽石 Diamond 時間限制: 1 s 空間限制: 128 ...


1225 八數位難題

 

 時間限制: 1 s  空間限制: 128000 KB  題目等級 : 鑽石 Diamond     題目描述 Description

Yours和zero在研究A*啟髮式演算法.拿到一道經典的A*問題,但是他們不會做,請你幫他們.
問題描述

在3×3的棋盤上,擺有八個棋子,每個棋子上標有1至8的某一數字。棋盤中留有一個空格,空格用0來表示。空格周圍的棋子可以移到空格中。要求解的問題是:給出一種初始佈局(初始狀態)和目標佈局(為了使題目簡單,設目標狀態為123804765),找到一種最少步驟的移動方法,實現從初始佈局到目標佈局的轉變。

輸入描述 Input Description

輸入初試狀態,一行九個數字,空格用0表示

輸出描述 Output Description

只有一行,該行只有一個數字,表示從初始狀態到目標狀態需要的最少移動次數(測試數據中無特殊無法到達目標狀態數據)

樣例輸入 Sample Input

283104765

樣例輸出 Sample Output

4

數據範圍及提示 Data Size & Hint

詳見試題

分類標簽 Tags 

代碼有點亂

思路還算清晰

bfs+hash判重

  1 #include<iostream>
  2 #include<cstdio>
  3 #include<cstdlib>
  4 using namespace std;
  5 const int MAXN=5;
  6 int xx[5]={-1,+1,0,0};
  7 int yy[5]={0,0,-1,+1};
  8 struct node
  9 {
 10     int mp[MAXN][MAXN];
 11 }a[100001];
 12 int hashfind[3733801];
 13 int step[200];
 14 int h=0,t=1;
 15 int bc[MAXN][MAXN]={{0,0,0,0},{0,1,2,3},{0,8,0,4},{0,7,6,5}};
 16 int hash()
 17 {
 18     int s=0;
 19     int k=1;
 20     for(int i=1;i<=3;i++)
 21     {
 22         for(int j=1;j<=3;j++)
 23         {
 24             s=s+a[t].mp[i][j]*k;
 25             k=k*7;
 26         }
 27     }
 28     s=s%3733801;
 29     if(hashfind[s]==0)
 30     {
 31         hashfind[s]=1;
 32         return 1;
 33     }
 34     else
 35     {
 36         return 0;
 37     }
 38 }
 39 int check()
 40 {
 41     for(int i=1;i<=3;i++)
 42     {
 43         for(int j=1;j<=3;j++)
 44         {
 45             if(a[t].mp[i][j]!=bc[i][j])
 46             return 0;
 47         }
 48     }
 49     return 1;
 50 }
 51 void move(int x,int y)
 52 {
 53     
 54     for(int i=0;i<4;i++)
 55     {
 56         int wx=x+xx[i];
 57         int wy=y+yy[i];
 58         if(wx>=1&&wx<=3&&wy>=1&&wy<=3)
 59         {
 60             for(int j=1;j<=3;j++)
 61             {
 62                 for(int k=1;k<=3;k++)
 63                     {
 64                         a[t].mp[j][k]=a[h].mp[j][k];
 65                     }
 66             }
 67             swap(a[t].mp[wx][wy],a[t].mp[x][y]);
 68             step[t]=step[h]+1;
 69             if(check()==1)
 70             {
 71                 printf("%d",step[t]);
 72                 exit(0);// end
 73             }
 74             if(hash()==1)
 75             t++;
 76         }
 77     }
 78 }
 79 void bfs()
 80 {
 81     while(h<t)
 82     {
 83         for(int i=1;i<=3;i++)
 84         {
 85             for(int j=1;j<=3;j++)
 86             {
 87                 if(a[h].mp[i][j]==0)
 88                 {
 89                     move(i,j);
 90                 }
 91             }
 92         }
 93         h++;
 94     }
 95 }
 96 int main()
 97 {
 98     char dr[10];
 99     int bgx=0;
100     int bgy=0;
101     gets(dr);
102     int now=0;
103     for(int i=1;i<=3;i++)
104     {
105         for(int j=1;j<=3;j++)
106         {
107             a[0].mp[i][j]=dr[now]-48;
108             if(a[0].mp[i][j]==0)
109             {
110                 bgx=i;
111                 bgy=j;
112             }
113             now++;
114         }
115     }
116     bfs();
117     return 0;
118 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 為什麼要學習設計模式 1、軟體開發越來越複雜,對軟體設計的要求也越來越高。而軟體設計和架構的入門功夫就是深入理解和掌握設計模式。因此,設計模式的重要性就不言而喻了。 2、設計模式已經成為軟體開發人員的“標準辭彙” 3、學習設計模式是個人提高的捷徑。為什麼這麼說呢?因為設計模式其本質是很多前輩(大牛級 ...
  • Given an array of integers, return indices of the two numbers such that they add up to a specific target. You may assume that each input would have e... ...
  • 這次的題目是這樣的: 假設有一個6*6的棋盤,每個格子裡面有一個獎品(每個獎品的價值在100到1000之間),現在要求從左上角開始到右下角結束,每次只能往右或往下走一個格子,所經過的格子里的獎品歸自己所有。問最多能收集價值多少的獎品。 最先看到這個問題的時候腦子裡面的立馬出現許多的腦洞:暴力、二叉樹 ...
  • 自動載入類 上傳代碼: ...
  • 本章介介紹了shutil,zipfile模塊的使用,我們先來認識一下這2個模塊吧。 一.shutil模塊 shutil模塊主要用於對文件或文件夾進行處理,包括:複製,移動,改名和刪除文件,在shutil模塊中主要以下這麼幾個函數: 1.複製文件和文件夾 shutil模塊提供了2個函數:shutil. ...
  • 1) { echo ""; return; } //HTTP頭部信息 header("Content-type: application/octet-stream"); header("Accept-Ranges: bytes"); he... ...
  • 下麵列出了當前可用的 PCRE 修飾符。括弧中提到的名字是 PCRE 內部這些修飾符的名稱。 模式修飾符中的空格,換行符會被忽略,其他字元會導致錯誤。 Warning This feature was DEPRECATED in PHP 5.5.0, and REMOVED as of PHP 7. ...
  • 讓我們來回憶下上次你是怎麼發佈你的代碼的: 1. 先把線上的代碼用ftp備份下來 2. 上傳修改了的文件 3. 測試一下功能是否正常 4. 網站500了,趕緊用備份替換回去 5. 替換錯了/替換漏了 6. 一臺伺服器發佈成功 7. 登錄每一臺執行一遍發佈操作 8. 加班搞定 9. 老闆發飆 ... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...