欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解CocosCreator華容道數(shù)字拼盤

 更新時間:2021年04月15日 10:52:25   作者:搬磚小菜鳥  
這篇文章主要介紹了詳解CocosCreator華容道數(shù)字拼盤,對華容道感興趣的同學,看完之后,可以回去親手試一下

前言

華容道是啥玩意?

這種數(shù)字拼圖游戲大家都玩過吧,他就是典型的華容道之一。

華容道是古老的中國民間益智游戲,以其變化多端、百玩不厭的特點與魔方、獨立鉆石棋一起被國外智力專家并稱為“智力游戲界的三個不可思議”。

今天咱們就來了解一下這個華容道。

正文

今天咱們主要以3*3的布局來進行,菜鳥用cocos creator 寫了一個簡單的demo,下面咱們逐步說一下

1.面板

首先咱們隨機生成一個面板排列

2.華容道求解

思路:

窮舉法:大家都知道這種游戲的玩法,滑動其中可以滑動的方格,將打亂的方格按照上邊數(shù)字從小到大的順序依次排列即可通關。在這里菜鳥利用了窮舉法,在每種可能的情況中去查找最優(yōu)解。

在窮舉法中我們常見的有:

  • 廣度搜索:廣度優(yōu)先搜索,會優(yōu)先搜索所有方向的第一步,然后再接著搜索每一個可行的方向的第二步,以此類推
  • 深度搜索:深度優(yōu)先搜索,會在一個方向一直搜下去,直到這條路走不通,才會考慮第二個方向

在這里我們用的是廣度優(yōu)先搜索,我們只需要拿到最優(yōu)解,也就是步數(shù)最少的。
具體操作如圖:

我們以前三步為例,

  • 第一步我們有三種走法,
  • 第二步我們需要在第一步的基礎上再移動方塊,每一種又會延伸出更多的可能性,
  • 我們需要把每一種可能性都存儲起來,
  • 下一步的移動是基于上一步所有可能性的基礎再去移動
  • 在第三步的時候我們會發(fā)現(xiàn) 會出現(xiàn)重復的情況,所有我們要進行減支,將重復的分支及時的處理掉,
  • 雖然處理掉了重復的分支,但是分支的數(shù)量也會成倍的增加,就拿示例中的排列,隨著步數(shù)的增加,分支的數(shù)量如圖顯示

  • 一旦有分支檢測到了已通關,那么廣度搜索就結束了
  • 最終會的得到每一步的一個移動過程

得到了解,我們可以應用到demo,檢測是否可以通關

點擊demo中的自動排列

3.代碼

//循環(huán)遍歷求解
while (true) {
    let steps: Array<any> = [];
    let lastGrad: Array<any> = this.mMapData[this.mMapData.length - 1];
    console.log(lastGrad.length);
    //遍歷作最后一個梯度中所有的結果,求解下一步
    for (let i = 0; i < lastGrad.length; i++) {
        let matrix = lastGrad[i]["matrix"];
        let answer = lastGrad[i]["answer"];
        let result: Array<any> = this.move(matrix, answer, steps);
        if (result) {
            console.log("結果:", result);
            resolve(result);
            return;
        }
    }

    if(steps.length<=0){
        console.log("查詢結果失敗,");
        resolve(null);
        return;
    }
    this.mMapData.push(steps);
}
private move(matrix: Array<number>, answer: Array<any>, steps: Array<any>): Array<any> {
    for (let i = 0; i < matrix.length; i++) {
        if (matrix[i] != -1) {  //不是空位,檢測是否可移動,獲取可移動結果
            //檢測上下左右是否可以移動,
            let result0: Array<any> = this.moveUp(i, matrix, answer, steps);
            let result1: Array<any> = this.moveDown(i, matrix, answer, steps);
            let result2: Array<any> = this.moveLeft(i, matrix, answer, steps);
            let result3: Array<any> = this.moveRight(i, matrix, answer, steps);

            if (result1) {
                return result1;
            }
            if (result2) {
                return result2;
            }
            if (result0) {
                return result0;
            }
            if (result3) {
                return result3;
            }
        }
    }
    return null;
}
private moveRight(i: number, matrix: Array<number>, answer: Array<any>, steps: Array<any>): Array<any> {
    let line: number = i % this.mLine;
    let row: number = Math.floor(i / this.mLine);
    if (line + 1 >= this.mLine) return null;  //超出邊界
    let targetIndex: number = row * this.mLine + (line + 1);
    if ( matrix[targetIndex] != -1) return null;  //不可移動
    //移動
    //移動
    //復制新的數(shù)組進行修改
    let newMatrix: Array<number> = JSON.parse(JSON.stringify(matrix));
    let newAnswer: Array<any> = JSON.parse(JSON.stringify(answer));
    //互換位置
    let temp: number = newMatrix[i];
    newMatrix[i] = newMatrix[targetIndex];
    newMatrix[targetIndex] = temp;
    newAnswer.push({ "index": i, "dic": 3 });

    if (this.checkIsExist(newMatrix)) {
        return null;
    }

    if (this.checkPass(newMatrix)) {
        return newAnswer;
    }
    let step: any = {};
    step["matrix"] = newMatrix;
    step["answer"] = newAnswer;
    steps.push(step);
}
/**
 * 檢測是否通關
 */
private checkPass(matrix: Array<number>): boolean {
    if (matrix[this.mRow * this.mLine - 1] != -1) return false;
    for (let i = 0; i < this.mRow * this.mLine - 1; i++) {
        if (matrix[i] != i + 1) {
            return false;
        }
    }
    console.log(matrix)
    return true;
}
/**
 * 檢測是否重復
 */
private checkIsExist(matrix): boolean {
    if (this.mMapMatrixS[JSON.stringify(matrix)]) {
        return true;
    }
    this.mMapMatrixS[JSON.stringify(matrix)] ="1";
    return false;
}

4.注意

demo中是3 * 3的排列,使用瀏覽器勉強可以跑出結果,但是4 * 4或者5 * 5的就不行了,因為分支太多。后續(xù)有時間菜鳥會用python腳本實現(xiàn)4 * 4,5 * 5或更多的排列,最終導出json關卡信息。

以上就是詳解CocosCreator華容道數(shù)字拼盤的詳細內(nèi)容,更多關于CocosCreator華容道的資料請關注腳本之家其它相關文章!

相關文章

  • javascript實現(xiàn)獲取服務器時間

    javascript實現(xiàn)獲取服務器時間

    本文給大家總結了一下使用javascript來獲取服務器時間的幾種方法和思路,十分的簡單明了,有需要的小伙伴可以參考下
    2015-05-05
  • JavaScript中的集合及效率

    JavaScript中的集合及效率

    由于 JavaScript 的語言特性,我們可以向通用對象動態(tài)添加和刪除屬性。所以 Object 也可以看成是 JS 的一種特殊的集合。
    2010-01-01
  • JS瀑布流實現(xiàn)方法實例分析

    JS瀑布流實現(xiàn)方法實例分析

    這篇文章主要介紹了JS瀑布流實現(xiàn)方法,結合實例形式分析了javascript瀑布流加載圖片效果的實現(xiàn)原理、步驟與相關操作技巧,需要的朋友可以參考下
    2016-12-12
  • 使用原生js實現(xiàn)拖拽和粘貼上傳圖片功能

    使用原生js實現(xiàn)拖拽和粘貼上傳圖片功能

    這篇文章主要介紹了使用原生js實現(xiàn)拖拽和粘貼上傳圖片功能,Vue/Rect?生態(tài)用多了都快忘記原生js怎么寫了,今天需要直接在服務器裸寫個頁面,實現(xiàn)?textarea?文本框里接收拖拽多個圖片,需要的朋友可以參考下
    2024-04-04
  • 微信小程序自定義音樂進度條的實例代碼

    微信小程序自定義音樂進度條的實例代碼

    最近遇到這樣的需求:顯示音樂播放按鈕、可手動拖拽進度條;頁面中含多個音樂,播放當前音樂時暫停其他音樂播放。 這篇文章主要介紹了微信小程序自定義音樂進度條的實例代碼,需要的朋友可以參考下
    2018-08-08
  • Javascript中for循環(huán)語句的幾種寫法總結對比

    Javascript中for循環(huán)語句的幾種寫法總結對比

    如果您希望一遍又一遍地運行相同的代碼,并且每次的值都不同,那么使用循環(huán)是很方便的,javascript中for循環(huán)也是非常常用的,下面這篇文章主要介紹了Javascript中for循環(huán)的幾種寫法,需要的朋友可以參考借鑒,一起來看看吧。
    2017-01-01
  • 利用types增強vscode中js代碼提示功能詳解

    利用types增強vscode中js代碼提示功能詳解

    這篇文章主要給大家介紹了如何增強vscode中js代碼提示功能的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。
    2017-07-07
  • JavaScript工廠模式詳解

    JavaScript工廠模式詳解

    這篇文章主要介紹了JavaScript設計模式之工廠模式,結合完整實例形式分析了工廠模式的概念、原理及javascript定義與使用工廠模式的相關操作技巧,需要的朋友可以參考下
    2021-10-10
  • Math.js解決js中小數(shù)精度丟失問題

    Math.js解決js中小數(shù)精度丟失問題

    在JavaScript中進行小數(shù)運算時,會容易出現(xiàn)精度丟失的問題,例如在進行兩個小數(shù)相加時,結果并不是預期的精確值,而是一個近似值,,使用第三方庫Math.js可以避免精度丟失的問題,本文導入Math.js庫和使用Math.js的方法來進行小數(shù)運算,同時還可以指定格式來保留小數(shù)位數(shù)
    2023-12-12
  • uniapp組件傳值的方法(父傳子,子傳父,對象傳值)實戰(zhàn)案例

    uniapp組件傳值的方法(父傳子,子傳父,對象傳值)實戰(zhàn)案例

    現(xiàn)在的前端開發(fā)中基本上都是組件化開發(fā)的,下面這篇文章主要給大家介紹了關于uniapp組件傳值(父傳子,子傳父,對象傳值)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-03-03

最新評論