- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我希望能够创建类似于老虎机结果的随机数数组。我知道如何提取随机数,但我想对整个结果进行加权。
例如,在下面的代码中,我只想允许 row2 在 10000 次中返回 [6,6,6] 1 。
我遇到的问题是我可以创建一个不会显示 6
的函数,除非万分之一,但这不是我想要的。我想将其显示在行中,但只是不想要特定的结果,除非每 10000 次旋转一次。
我想为所有获胜盘设置不同的赔率。有什么建议吗?
这是迄今为止我的代码:
var row1 = [0, 0, 0];
var row2 = [0, 0, 0];
var row3 = [0, 0, 0];
var bar1 = 1;
var bar2 = 2;
var bar3 = 3;
var cherry = 4;
var seven = 5;
var diamond = 6;
var balance = 100;
function loadBalance(buyIn) {
return (balance += buyIn);
}
var reelArray = [1, 2, 3, 4, 5, 6];
function randomChoice(arr) {
const randIndex = Math.floor(Math.random() * arr.length);
return arr[randIndex];
}
function spin() {
for (j = 0; j <= 2; j++) {
row1[j] = randomChoice(reelArray);
row2[j] = randomChoice(reelArray);
row3[j] = randomChoice(reelArray);
}
console.log(`${row1}\n${row2}\n${row3}`);
}
function play() {
spin();
checkWinner();
}
function checkWinner() {
if (row2[0] != row2[1]) {
console.log("you lost");
balance = balance - 1;
console.log(`bal: `, balance);
return balance;
} else if (row2[1] != row2[2]) {
console.log("you lost");
balance = balance - 1;
console.log(`bal: `, balance);
return balance;
} else {
console.log("you won!");
switch (row2[0]) {
case 1:
balance = balance + 20;
console.log(`bal: `, balance);
break;
case 2:
balance = balance + 40;
console.log(`bal: `, balance);
break;
case 3:
balance = balance + 80;
console.log(`bal: `, balance);
break;
case 4:
balance = balance + 20;
console.log(`bal: `, balance);
break;
case 5:
balance = balance + 200;
console.log(`bal: `, balance);
break;
case 6:
balance = balance + 1000;
console.log(`bal: `, balance);
break;
default:
break;
}
}
return;
}
function runIt() {
for (i = 0; i <= 100; i++) {
play();
}
}
runIt();
最佳答案
要更改特定结果的赔率吗?
您可以检查这些特定分数,然后进行额外的随机检查。
下面是模拟和计算此类方法的代码片段。
它不能保证被操纵的结果每 N 次中就有 1 次被准确地选取。
但它们发生的几率会降低。
另一种方法是存储一个带有操纵结果计数器的对象。然后仅当此类操纵结果的计数器仍低于其限制时才递归。当它被允许通过时重置它的计数器。但知道使用这种方法的赌徒只能等待其他赌徒浪费赌注并愤怒退出。然后在接近该限制之前接管。从而增加了他获胜的几率。
const reelWords = ['bar1', 'bar2', 'bar3', 'cherry', 'seven', 'diamond'];
const riggedOdds = { 111: 100, 222: 200, 333: 300, 444: 400, 555: 500, 666: 10000 };
const winningcombos = [111, 222, 333, 444, 555, 666];
function getRandomReel(elementLimit) {
let N = (elementLimit < 2) ? 2 : elementLimit;
if(N > reelWords.length) N = reelWords.length;
let arrNums = [];
let arrWords = [];
while(arrNums.length < 3){
let idx = Math.floor(Math.random() * N); // random 0 to N-1
arrNums.push(idx+1);
arrWords.push(reelWords[idx]);
}
let arrCombo = Number(arrNums.join(''));
if(arrCombo in riggedOdds){
let riggedOdd = riggedOdds[arrCombo];
let newOdd = Math.floor(riggedOdd/(N*N*N));
let n = Math.floor(Math.random()*(newOdd+1));
//console.log('combo:'+ arrCombo +', rigged:'+ riggedOdd +', new odd:'+ newOdd +', n:'+ n);
if(n > 0) {
return getRandomReel(N); // recurse
}
}
return {"combo": arrCombo, "words": arrWords };
}
function printDictAsTable(dict){
let htmlstr = "<table border=1><tr><th>Number</th><th>Count</th></tr>";
let sortedKeys = Object.keys(dict).sort(function(a,b){return b-a});
for (let i=0; i<sortedKeys.length; i++) {
let key = sortedKeys[i];
htmlstr += "<tr><td>"+ key +" </td><td>" + dict[key] + " </td></tr>";
}
htmlstr += "</table>";
document.getElementById("resultContainer").innerHTML = htmlstr;
}
function loopRiggedOneArmedBanditSimulationAndPrint(){
let elementLimit = Number(document.getElementById("elementLimit").value);
let loopTotal = Number(document.getElementById("loopLimit").value);
let dict = {};
for(let i = 0; i < loopTotal; i++){
let reel = getRandomReel(elementLimit);
let combo = reel.combo;
dict[combo] = dict[combo] ? dict[combo] + 1 : 1;
}
printDictAsTable(dict);
}
function GambleAndPrint() {
let elementLimit = reelWords.length;
document.getElementById("rangeInput").value = elementLimit ;
document.getElementById("elementLimit").value = elementLimit;
let htmlstr = "<table border=1>";
for(let i = 0; i < 3; i++){
let reel = getRandomReel(elementLimit);
let arr = reel.words;
let winorlose = (winningcombos.indexOf(reel.combo) > -1) ? 'won' : '...';
htmlstr += "<tr><td>"+arr[0]+"</td><td>"+arr[1]+"</td><td>"+arr[2]+"</td><td>"+ winorlose +"</td></tr>";
}
htmlstr += "</table>";
document.getElementById("resultContainer").innerHTML = htmlstr;
}
loopRiggedOneArmedBanditSimulationAndPrint();
<div id="topContainer">
<div id="inputAndButton" style="float: left;">
<p>Elements :
<input type="number" id="elementLimit" value=2 readonly><br/>
<input type="range" id="rangeInput" min=2 max=6 value=2 onchange="document.getElementById('elementLimit').value=this.value;">
</p>
<p>Loops: <input type="number" id="loopLimit" value=10000></p>
<p><button type="button" onclick="loopRiggedOneArmedBanditSimulationAndPrint()">
Loop and Count Simulation
</button>
<button type="button" onclick="GambleAndPrint()">
Gamble
</button>
</p>
</div>
<div id="resultContainer" style="float: right;"></div>
</div>
关于javascript - 数组中带有权重的随机数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51345563/
我有几个系统,其中包含用户表以及某种形式的业力/权重/声誉。有时是用户发布的帖子数量,有时是用户在网站上的所有事件中收到的赞成/反对票数。 USER { id int name str
我需要能够使用填充的相对大小 - 根据设备的分辨率和 dpi 变大或变小。 例如,如果我的 View 宽度为 100 像素,我希望左侧填充 10 像素,右侧填充 10 像素。但是,如果它在更高密度的屏
我目前正在使用由大约 10 个字段组成的 Solr 索引数据。当我执行搜索时,我希望某些字段的权重更高。谁能帮我指出正确的方向? 例如,在所有字段中搜索“超人”等术语时,应在“Description”
我正在使用 igraph 模拟网络随时间的变化在 r并且我正在寻找一种有效且可扩展的方式来对此进行编码以用于业务。 网络变化的主要驱动因素是: 新增节点 新领带 新节点权重 在第一阶段,在 100 个
我一直在寻找一种使用OpenVINO框架上的C++ API获取网络每一层权重/参数和偏差张量的方法。我在文档中找不到任何内容,在示例中也找不到任何示例。我如何提取这些张量? 谢谢, 塞萨尔 编辑: 分
我的问题与 PHP Memcache 扩展的 addServer 函数中的“weight”参数有关。 在过去的几个月里,我一直在为所有服务器使用“weight = 1”。我现在正在尝试应用以下配置以最
我应该使用哪种数据结构来保持元素按给定权重排序?我需要在集合中添加元素,其中每个元素都会生成特定的权重,但该权重不包含(也不计算)在元素本身内部;它是由元素之外的其他人计算的。而且,权重不需要存储(但
我正在尝试在 keras/tensorflow 中使用具有多个类的焦点损失,这导致使用我猜的分类焦点损失。我找到了一些实现here和 there或there 。 据我了解,焦点损失中的参数a主要用于二
我有一个像这样的 Pandas 数据框: df = pd.DataFrame({'id': [121, 34324, 111, 12, 45, 232], 'weight'
我有一个带有输出神经元的神经网络,我想在软最大化之前使用经过训练的权重进行线性缩放。 我有 10 个输出,我想要 10 个权重,在输出被软最大化之前乘以每个输出。因此每个输出的权重为 1。 但我不断收
我有这样的布局: 我希望它看起来像: TextView - 宽度的 40%,带 ImageView 的布局
这让我彻底疯了。我想在 android 中使用有点复杂的布局。我正在尝试使用权重而不是固定事物的大小。也许我应该放弃…… 这是我想做的: 我想要 3 个 ScrollView (里面有 TextVie
我正在尝试开发类似于网格但使用 LinearLayout。我想在单行中有 3 张图像和图像后的确切底部文本。 我尝试过的: LinearLayout layout = new LinearLayout
我想在同一行添加一个 EditText 和一个 Button,我想将 80% 的行给 editText,20% 给 Button。 这是我的代码:
我有一个 mysql 表,其中存储一列(称为 tickets),并且 tickets 值可以是任意数字。 我想要做的是有一个mysql查询,从列中选择所有行,按降序对它们进行排序,然后使用PHP对查询
我搜索了一段时间,但结果让我很困惑,因为我对 MySQL 还很陌生。 我有一个包含这 4 列的表:AUTO_INCREMENT ID、NAME、TYPE、CHANCE 所以行看起来像这样: 1, NO
我不完全是 JS 专业人士,虽然不漂亮或高效,但这是有效的。 实际上,我在表单中有重复的字段组,并允许用户根据需要将数据从第一个字段复制到所有 5 个字段。 如何使这段代码更高效? function
我正在使用xgboost库来训练二元分类器。我想通过向权重添加噪声(例如集合中树的叶节点的值)来防止训练算法的数据泄漏。为此,我需要检索每棵树的权重并修改它们。 我可以通过在 Booster 对象上使
我正在尝试让 LinearLayout 中的 View 填充宽度。我尝试使用 LayoutParams 设置它,但它给了我一个错误: 我的代码: EditText et = new EditText(
我想改变 ScrollView 的权重,但找不到实现它的方法。 这是我的 XML: **other layout.. 从代码中只能设置scrollView的高度或者宽度,weigh
我是一名优秀的程序员,十分优秀!