在精确位置数组中搜索

Posted

技术标签:

【中文标题】在精确位置数组中搜索【英文标题】:Search in array of precise positions 【发布时间】:2022-01-21 21:14:36 【问题描述】:

我目前有一幅有 64 块瓷砖的画,每种颜色都已定义。灰色是有效位置,黑色是无效位置(墙),绿色是玩家棋子 1,红色是玩家棋子 2。当玩家 1 点击他的绿色棋子时,他可以选择在靠近他的有效瓷砖上复制自己(灰色)或跳到靠近他的第二块瓷砖上。如果绿色棋子是靠近红色棋子的瓷砖,它就会变成绿色现在我正在寻找的是。

如何搜索所有有效位置,无论是准备好的瓷砖还是在 2 日跳跃并正确检查之后的内容。

class Game
        constructor()
            super();
            this.default_grid = null;
            this.curr_grid_playing = null;
            this.player = 1;
            this.curr_player_turn = 1;
            this.game_is_ready = false;
            this.rows = [];

            this.do_new_game();
        

        get_random_grid()
            const array_grid = [
                "3100000010000000000000000003300000033000000000000000000200000023",
                "1000000200300300033003300000000000000000033003300030030010000002",
                "0000000000000000033300300313203003013230030033300000000000000000",
                "0000000000000000003033000313003003230030003033000000000000000000"
            ];
            return array_grid[Math.floor(Math.random()*array_grid.length)];
        

        do_new_game()
            this.default_grid = this.get_random_grid();
            this.curr_grid_playing = this.default_grid;
            
            for(let i = 0; i < this.default_grid.length; i++)   
                if(i % 8 == 0)
                    this.rows.push([]);
                this.rows[this.rows.length - 1].push([i, this.default_grid.charAt(i)]);

                let new_game_node = this.create_game_button(this.default_grid.charAt(i), i);
                this.append_child_node(new_game_node);
                
                 
        

        get_grid_possibilities(from_index)
            if(this.curr_player_turn == 1 && (this.curr_player_turn == this.player))
               console.log(this.rows);
               
             else if(this.curr_player_turn == 2 && (this.curr_player_turn == this.player))

            
        
    

我正在考虑在数组中制作一个图形来准确表示网格 是我们的控制台显示的内容,它可以工作,但我不确定它是否不太复杂。

【问题讨论】:

【参考方案1】:

您已经有了代表棋盘游戏的矩阵,因此您只需检查 -1 和 +1 方格。

let characterPosition = x:5, y:5;

for (let row-1; row<=1; row++) 
    for (let col-1; col<=1; col++) 
        
        let testPosX = characterPosition.x + col;
        let testPosY = characterPosition.y + row;
        
        if (row===0 && col===0) 
            // player pos -> skip
            break;
        
        
        if (testPosX<0 || testPosY<0 || testPosY>matrix.length-1 || testPosX>matrix[0].length-1) 
            // outside board -> skip
            break;
        
        
        if (matrix[testPosY][testPosX]===0) 
            // this is a empty square
         else 
            // this is not an empty square
        
        
    

【讨论】:

那么跳到靠近他的第二个瓷砖怎么样。 如果你可以跳跃,那么只需使用-2和+2。如果不能,则需要通过逐步移动和检查来对探路者进行编程。

以上是关于在精确位置数组中搜索的主要内容,如果未能解决你的问题,请参考以下文章

在Elasticsearch中的数组中进行精确的字符串搜索

精确二分搜索与非精确二分搜索

使用 JavaScript 在 JSON 中搜索精确匹配

在数组中查找多个精确值

SwiftUI List 需要精确的位置来渲染结果,所以如果没有 [0] 等就不会渲染结果

es对中文进行精确查询