[經典演算法]8皇後問題sql求解(回溯演算法)

来源:https://www.cnblogs.com/yongestcat/archive/2018/08/08/9442722.html
-Advertisement-
Play Games

八皇後問題是一個古老而著名的問題,是回溯演算法的典型例題,直接用sql來求解 ...


問題:

八皇後問題是一個古老而著名的問題,是回溯演算法的典型例題。該問題是十九世紀著名的數學家高斯1850年提出:在8X8格的國際象棋上擺放八個皇後,使其不能互相攻擊,即任意兩個皇後都不能處於同一行、同一列或同一斜線上,問有多少種擺法

百度來的代碼:

回溯法用遞歸實現八皇後解法

declare
  type t_queen is varray(8) of number;
  queen t_queen := t_queen(1, 2, 3, 4, 5, 6, 7, 8);
  l_num number := 0;
  -- 顯示“八皇後”
  procedure show(queen t_queen) is
  begin
    l_num := l_num + 1;
    dbms_output.put_line(rpad('---- NO. ' || l_num || ' ', 16, '-'));
    -- 從第1行顯示到第8行
    for r in 1 .. 8 loop
      -- 當前行,從第1列顯示到第8列
      for c in 1 .. 8 loop
        -- “皇後”用“Q”表示,空位用“.”表示
        dbms_output.put(case when queen(r) = c then 'Q' else '.'
                        end || ' ');
      end loop;
      dbms_output.put_line(null);
    end loop;
  end;
  -- 衝突檢測。檢測第row行與第1行至第row-1行是否衝突。
  -- 不衝突,返回true;衝突返回false
  function is_ok(queen t_queen, row number) return boolean is
    t number;
  begin
    for r in 1 .. row - 1 loop
      if queen(r) = queen(row) then
        -- 第row行與第r行的皇後在同一列上,衝突
        return false;
      end if;
      t := queen(r) - queen(row);
      if t = r - row or t = row - r then
        -- 第row行與第r行的皇後在同一斜線上,衝突
        return false;
      end if;
    end loop;
    return true;
  end;
  -- 遞歸查找所有排列
  procedure find(queen in out t_queen, row number) is
  begin
    for col in 1 .. 8 loop
      -- 每一行列的位置從第1列到第8列檢測
      queen(row) := col;
      if is_ok(queen, row) then
        if row = 8 then
          -- 已經查找到第8行,查找結束,顯示結果
          show(queen);
          return;
        end if;
        find(queen, row + 1); -- 尚未查找到第8行,第歸查找一下行
      end if;
    end loop;
  end;
begin
  find(queen, 1); -- 從第1行開始查找
end;

運行結果:

image92種結果展示的非常清晰

 

 

還有百度到了另外一種更簡潔的寫法,

利用Oracle 11R2版本的遞歸屬性,演算法很簡單,也就是在斜線上,直線上無衝突即可

with sou as (
     select level n,1 k from dual connect by  level<=8
),
     ntt(n,k) as (
     select sou.n ,sou.k  from sou where k=1
     union all
     select ntt.n*10+a.n
            ,ntt.k+1 
     from ntt,sou a
     where not exists(select 1
                      from  (select level b1 from dual connect by level<=7) t
                      where t.b1<=ntt.k and (
                             a.n=to_number(substr(to_char(ntt.n),b1,1)) or
                             a.n=to_number(substr(to_char(ntt.n),b1,1))+(ntt.k+1-t.b1) or
                             a.n=to_number(substr(to_char(ntt.n),b1,1))-(ntt.k+1-t.b1)
                             )
                     ) and ntt.k<=7
     )
select n from ntt where ntt.k=8  ;

image

結果是一個數字表示在棋盤上的位置,也可以改一下用兩位整數表示一個棋位,這樣可以擴展到10皇後以上。

時間因素:

也即每增加一個皇後,增加的時間約為上一個的e(x+1)倍


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

-Advertisement-
Play Games
更多相關文章
  • DNS(Domain Name System,功能變數名稱系統),網際網路上作為功能變數名稱和IP地址相互映射的一個分散式資料庫,能夠使用戶更方便的訪問互聯網,而不用去記住能夠被機器直接讀取的IP數串。 查看dns 可以使用 /etc/resolv.conf 文件,nslookup 命令 和 dig 命令: 配置 d ...
  • 1 海量數據的存儲問題 如今隨著互聯網的發展,數據的量級也是撐指數的增長,從GB到TB到PB。對數據的各種操作也是愈加的困難,傳統的關係性資料庫已經無法滿足快速查詢與插入數據的需求。這個時候NoSQL的出現暫時解決了這一危機。它通過降低數據的安全性,減少對事務的支持,減少對複雜查詢的支持,來獲取性能 ...
  • 占座 ...
  • [20180808]exists and not exists.txt--//生產系統遇到的一個性能問題,通過例子來說明:1.環境:SCOTT@test01p> @ ver1PORT_STRING VERSION BANNER CON_ID IBMPC/WIN_NT64-9.1.0 12.1.0.1 ...
  • 一、基本概念 1.資料庫: 資料庫(DataBase)就是一個存儲數據的倉庫,為了方便數據的存儲和管理,它將數據按照特定的規律存儲在磁碟上。通過資料庫管理系統,可以有效的組織和管理存儲在資料庫中的數據。資料庫是數據管理軟體。數據存儲分為三個階段:人工管理階段、文件系統階段和資料庫系統階段。 2.數據 ...
  • 一.key_buffer 上一篇瞭解key_buffer設置,key_buffer_size指定了索引緩衝區的大小,它決定索引處理的速度,尤其是索引讀的速度。通過檢查狀態值Key_read_requests和Key_reads,可以知道key_buffer_size設置是否合理。比例key_read ...
  • 一.概述 這篇介紹Stolen記憶體相關的主要三種等待類型以及對應的waittype編號,CMEMTHREAD(0x00B9),SOS_RESERVEDMEMBLOCKLIST(0x007B),RESOURCE_SEMAPHORE_QUERY_COMPILE(0x011A)。也可以通過sysproce ...
  • 1. 什麼是redis? Redis 是一個使用 C 語言寫成的,開源的基於記憶體的高性能key value資料庫。 Redis的值可以是由string(字元串)、hash(哈希)、list(列表)、set(集合)、zset(有序集合)、Bitmaps(點陣圖)等多種數據結構組成。 2. Redis的特 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...