- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是一款扫雷游戏。这里的目标是生成准确数量的地雷。在本例中,我有一个 8x8 网格的盒子,里面有 10 个地雷(见底部)。因此,嵌套的 for 循环生成了 64 个带有 x
和 y
坐标(用于稍后绘制网格)的对象,以及一个 state
属性来指示是否领域已布有地雷。然后,在 generateBombs
中,我使用 state:mined
生成 10 个对象,并使用随机的 x
和 y
来覆盖其中的 8 个对象。盒子里的64个物体随机排列,从而埋下地雷。我的方法的问题在于,有可能生成 2 个非唯一的 x
和 y
对象对,这样我最终会得到比原来的地雷数量要少,因为同一个对象会被覆盖两次。这里有什么好的方法?
此外,我的要求之一是生成器对地雷使用辅助函数,但它们采用相同的参数,因此该需求可能会被击败。
var minesweeper = {
boxes: [],
//rows
boxesNum: 0,
bombsNum: 0,
//creates a 8x8 grid
generateMap: function (width, height, bombsNum) {
for (i = 1; i < height; i++) {
this.boxes.push({
x: i,
y: 1,
state: "safe"
});
for (j = 1; j < width; j++) {
this.boxes.push({
x: 1,
y: j,
state: "safe"
});
}
}
this.generateBombs(width, height, bombsNum)
},
//mines random fields from the grid
generateBombs: function (width, height, bombsNum) {
for (k = 0; k < bombsNum; k++) {
this.boxes.push({
x: Math.floor(Math.random() * width + 1),
y: Math.floor(Math.random() * height + 1),
state: "mined"
});
}
}
}
minesweeper.generateMap(8, 8, 10);
最佳答案
你最好先处理盒子阵列本身,而不是先生成炸弹。
generateBombs: function (width, height, bombsNum) {
var bombCount = 0; // Count how many bombs we planted,
while(bombCount < 10){ // Loop until we have 10 bombs,
var index = parseInt(Math.random() * this.boxes.length + 1); // Get a random box id,
if(this.boxes[index].state === "safe"){ // If the box is safe, plant a bomb.
this.boxes[index].state = "mined";
bombCount++; // Increase bomb count with 1.
}
}
}
此方法将保证您在 10 个不同位置放置了 10 个炸弹。它可以选择同一个框两次,但如果这样做,它只会再试一次。
在最好的情况下,与需要为要生成的每个炸弹检查坐标数组的其他方法相比,您有 10 次循环迭代。
但是,这种随机选择炸弹位置的方法有一个问题:
如果增加炸弹数量,该方法将击中越来越多已放置炸弹的盒子,从而导致放置所需数量的炸弹所需的迭代次数呈指数级增长。基本上,磁场越密集,函数就越有可能随机选择一个已经有炸弹的单元格,因此必须重试。
不过,我预计这在炸弹数量为 50% 或更低时不会很明显。
<小时/>你的generateMap
函数也被破坏了。试试这个:
generateMap: function (width, height, bombsNum) {
for (var i = 0; i < width; i++) {
for (var j = 0; j < height; j++) {
this.boxes.push({
x: (i + 1),
y: (j + 1),
state: "safe"
});
}
}
this.generateBombs(width, height, bombsNum)
},
关于javascript - 确保我的 for 循环恰好生成 8 个唯一的数字对,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31402442/
考虑具有 V 个顶点和 E 个边的图 G(V,E)。我们想用恰好 K 种颜色给顶点图着色。 着色图是指以两个相邻顶点不应该具有相同颜色的方式为每个节点分配颜色。 我们如何实现这个问题? 最佳答案 首先
我遇到的问题可以简化为: Given an array of N positive numbers, find the non-contiguous sequence of exactly K ele
根据这些问题 Subset sum problem和 Sum-subset with a fixed subset size我想知道解决子集和问题的一般算法是什么,我们被迫使用恰好 k 个整数,k <
我想从具有模式的行中取出数字,但它不会按照我的意愿对数字进行分组。 public static void main(String[] args) { Pattern pattern = Pat
我试图弄清楚用于查找与一组字符恰好 N 次出现(不多于少)匹配的正则表达式。这看起来是一项非常简单的任务,但我一直无法为其找到合适的正则表达式。 更具体地说,我想要一个正则表达式来判断给定字符串是否恰
我试过同时使用 httpx 和 aiohttp,并且都有这个硬编码限制。 import asyncio import aiohttp import httpx async def main():
我有一个在 Amazon EC2 云中运行的服务器应用程序。从我的客户端(浏览器)我发出一个 HTTP 请求,该请求将文件上传到服务器,然后服务器处理该文件。如果有很多处理(大文件),服务器总是在 1
我在 PHP 中使用带有 preg_match 函数的 perl 风格的正则表达式。我想验证一个恰好 10 个字符的 key ,包含大写字母字符或数字。 我有 preg_match( '/[^A-Z0
我正试图找到正确的 python 正则表达式来解决这个问题: 给定一个由字符 ?、_ 和 o 组成的字符串,找到长度为 n 的子字符串> 仅包含 ? 和 o 以及至少一个 o。 这是我想出来的,但它似
图中每条边的权重为 1,图中可能有环,如果一个节点有自环,它可以是从 0 到无穷大的任何距离,具体取决于编号。时间我们采取 self 循环。 我已经用bfs解决了这个问题,但是对距离的约束是10^9的
我有一个居中的 DIV,正好(不多也少)900px。我希望它始终居中,并让两个填充 div 填充每一侧页面的其余部分... 给下面的内容(使用 z-index)一个突出显示的类型效果...(这是填充
我的 Xcode 版本是 10.2。当我将应用程序上传到 iTunes Connect 时,显示以下错误: Missing required icon file. The bundle does no
我是一名优秀的程序员,十分优秀!