- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在 2 个范围(例如 100 到 150)之间生成总和为 N 的随机数。
到目前为止我做了什么:
function randomNumbers() {
let i, nb, min, max, totAtteindre, tot, ajout;
let resultat = new (Array);
let alea = [];
nb = document.getElementById("nbjours").value;
totAtteindre = document.getElementById("total").value;
min = Math.ceil(document.getElementById("minimum").value);
max = Math.floor(document.getElementById("maximum").value);
tot = 0;
for (i = 0; i < nb ; i++)
{
alea[i] = Math.random() * (max - min) + min;
alea[i] = alea[i].toFixed(2);
alea[i] = parseFloat(alea[i]);
tot += alea[i];
}
tot = parseFloat(tot);
if (totAtteindre > tot)
{
ajout = (totAtteindre - tot) / nb;
ajout = ajout.toFixed(2);
ajout = parseFloat(ajout);
for (i = 0; i < nb ; i++)
{
alea[i] += ajout;
tot += ajout;
}
}
else
{
ajout = (tot - totAtteindre) / nb ;
ajout = ajout.toFixed(2);
ajout = parseFloat(ajout);
for (i = 0; i < nb ; i++)
{
alea[i] -= ajout;
tot -= ajout;
}
}
let tmp = totAtteindre - tot;
tot += tmp;
alea[0] += tmp;
// Affichage en vert ou rouge pour les valeurs positives ou négatives
for (i = 0; i < nb ; i++)
{
if ((alea[i] > min) && (alea[i] < max))
{
resultat += alea[i].toFixed(2).replace('.', ',').fontcolor("green");
if (i < nb-1)
{
resultat += "<br>";
}
}
else
{
resultat += alea[i].toFixed(2).replace('.', ',').fontcolor("red");
if (i < nb-1)
{
resultat += "<br>";
}
}
}
document.getElementById("valeurs").innerHTML = resultat;
document.getElementById("totalAp").innerHTML = tot.toFixed(2);
}
<body>
<main>
<header>
<h1 style="font-size: 40px; text-align: center; margin: 20px; border: solid 2px black; font-family: 'Big Caslon'"><strong>Générateur de valeurs aléatoires</strong></h1>
</header>
<section>
<form style="display: block; margin: 20px; text-align: center;">
<h1 style="margin-bottom: 50px; font-family: 'Big Caslon';" ><u>Veuillez saisir le nombre de valeurs, les bornes inférieures/supérieures approximatives et le montant à atteindre</u><br></h1>
<fieldset>
<legend><strong>Nombre de valeurs</strong></legend>
<input id="nbjours" type="number" name ="nbj">
</fieldset>
<br>
<fieldset>
<legend><strong>Bornes journalières approximatives</strong></legend>
<input id="minimum" type="number" name="mont1">
<input id="maximum" type="number" name="mont2">
<div class="help-tip">
<p style="text-align: justify; font-size: smaller">Il est possible d'avoir un résultat dont les valeurs dépassent les bornes. <br>Dans ce cas-là, diminuez les bornes ou augmentez les.</p>
</div>
</fieldset>
<br>
<fieldset>
<legend><strong>Montant à atteindre</strong></legend>
<input id="total" type="number" name="to">
</fieldset>
</form>
<div style="display: flex; justify-content: center; margin: 20px;">
<button onclick="randomNumbers()" class="myButton">Générer</button>
</div>
</section>
<section style="display: block; text-align: center; margin-top: 10px; width: 50%; margin-left: auto; margin-right: auto">
<fieldset>
<legend style="background-color: unset;">
<button onclick="copyText('valeurs')">
Copier les valeurs
</button>
<br>
</legend>
<div id="valeurs" ></div>
</fieldset>
</section>
<section style="text-align: center; margin: 10px; width: 30%; display: block; margin-left: auto; margin-right: auto">
<fieldset>
<legend style="background-color: firebrick"><strong>Total</strong></legend>
<div id="totalAp"></div>
</fieldset>
</section>
</main>
</body>
</html>
如您所见,有时您会得到低于最小值或最大值的值。
因为我将剩余的总数除以值的数量并将它们添加到每个值。
我不知道是否有一种方法可以像方法一样严格地只获取两个范围(最小值和最大值)之间的值。我也许可以做 if 语句,不将附加值添加到那些会超过最小/最大值并划分更多的值。但我试过了,我仍然会得到一两个不在严格范围内的结果。
最佳答案
此函数有四个参数:size
、min
、max
和 sum
- 其中 size
是您要生成的数组的长度。如果您传递的 mix
/max
/size
组合是一项不可能完成的任务,则将返回 false
,这意味着要么选择每次都选择最小值仍然太高,或者每次都选择最大值仍然太低。
为了创建数组(称为 set
),我们选择 size - 1
随机数,每次从我们想要的 sum
中减去随机数>。重要的是,我们还检查每个选择,确保选择不会导致每次选择最小值仍然太高或每次选择最大值仍然太低的情况。如果我们发现是这种情况,我们的 while
循环会废弃该随机数并选择一个不同的随机数。因为我们使用这种方法永远不会为失败做好准备,所以我们只需要选择 size - 1
随机数,而 sum
变量中剩下的保证是在我们的 min
/max
范围内,并使我们的总数达到我们最初想要的总和。
这里的瓶颈是我们要求两个数字之间的随机 float ,但如果它不符合我们不可告人的动机,则拒绝它。太多的拒绝会减慢速度,所以你留下越多的填充来玩,这可能表现得越好。例如,randomSet(10, 50, 100, 500);
实际上肯定会停止(因为我们必须连续 10 次恰好选择 50.00000 - 机会有多大其中的??),而 randomSet(10, 50, 100, 750);
几乎不需要时间就可以成功完成。
function randomSet(size, min, max, sum) {
if (min * size > sum || max * size < sum) return false;
var set = [];
for (; size > 1; size--) {
var randomNumber = rando(min, max, "float");
while (min * (size - 1) > sum - randomNumber || max * (size - 1) < sum - randomNumber) {
randomNumber = rando(min, max, "float");
}
set.push(randomNumber);
sum -= randomNumber;
}
set.push(sum);
return set;
}
var myRandomSet = randomSet(30, 100, 200, 4500);
console.log(myRandomSet);
console.log("SUM: " + myRandomSet.reduce((a, b) => a + b, 0));
<script src="https://randojs.com/1.0.0.js"></script>
如果你想要四舍五入到百分之一的 float :
function randomSet(size, min, max, sum) {
if (min * size > sum || max * size < sum) return false;
var set = [];
for (; size > 1; size--) {
var randomNumber = Math.round(rando(min, max, "float") * 100) / 100;
while (min * (size - 1) > sum - randomNumber || max * (size - 1) < sum - randomNumber) {
randomNumber = Math.round(rando(min, max, "float") * 100) / 100;
}
set.push(randomNumber);
sum -= randomNumber;
}
set.push(Math.round(sum * 100) / 100);
return set;
}
var myRandomSet = randomSet(30, 100, 200, 4500);
console.log(myRandomSet);
console.log("SUM: " + myRandomSet.reduce((a, b) => a + b, 0));
<script src="https://randojs.com/1.0.0.js"></script>
此代码使用 randojs.com简化最小/最大 float 随机性,因为该算法足够复杂,而无需将常见的随机性数学混入其中。所以,如果你想使用这段代码,只需确保将它包含在你的 html 文档的 head 标签中:
<script src="https://randojs.com/1.0.0.js"></script>
关于javascript - 2 个范围(例如 100 和 150)之间的随机 30 个数字( float ),总和为 N,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60214727/
我看到以下宏 here . static const char LogTable256[256] = { #define LT(n) n, n, n, n, n, n, n, n, n, n, n,
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
所以我得到了这个算法我需要计算它的时间复杂度 这样的 for i=1 to n do k=i while (k<=n) do FLIP(A[k]) k
n 的 n 次方(即 n^n)是多项式吗? T(n) = 2T(n/2) + n^n 可以用master方法求解吗? 最佳答案 它不仅不是多项式,而且比阶乘还差。 O(n^n) 支配 O(n!)。同样
我正在研究一种算法,它可以在带有变音符号的字符(tilde、circumflex、caret、umlaut、caron)及其“简单”字符之间进行映射。 例如: ń ǹ ň ñ ṅ ņ ṇ
嗯..我从昨天开始学习APL。我正在观看 YouTube 视频,从基础开始学习各种符号,我正在使用 NARS2000。 我想要的是打印斐波那契数列。我知道有好几种代码,但是因为我没有研究过高深的东西,
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭12 年前。 Improve th
谁能帮我从 N * N * N → N 中找到一个双射数学函数,它接受三个参数 x、y 和 z 并返回数字 n? 我想知道函数 f 及其反函数 f',如果我有 n,我将能够通过应用 f'(n) 来
场景: 用户可以在字符串格式的方程式中输入任意数量的括号对。但是,我需要检查以确保所有括号 ( 或 ) 都有一个相邻的乘数符号 *。因此 3( 应该是 3*( 和 )3 应该是 )*3。 我需要将所有
在 Java 中,表达式: n+++n 似乎评估为等同于: n++ + n 尽管 +n 是一个有效的一元运算符,其优先级高于 n + n 中的算术 + 运算符。因此编译器似乎假设运算符不能是一元运算符
当我阅读 this 问题我记得有人曾经告诉我(很多年前),从汇编程序的角度来看,这两个操作非常不同: n = 0; n = n - n; 这是真的吗?如果是,为什么会这样? 编辑: 正如一些回复所指出
我正在尝试在reveal.js 中加载外部markdown 文件,该文件已编写为遵守数据分隔符语法: You can write your content as a separate file and
我试图弄清楚如何使用 Javascript 生成一个随机 11 个字符串,该字符串需要特定的字母/数字序列,以及位置。 ----------------------------------------
我最近偶然发现了一个资源,其中 2T(n/2) + n/log n 类型 的递归被 MM 宣布为无法解决。 直到今天,当另一种资源被证明是矛盾的(在某种意义上)时,我才接受它作为引理。 根据资源(下面
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
我完成的一个代码遵循这个模式: for (i = 0; i < N; i++){ // O(N) //do some processing... } sort(array, array + N
有没有办法证明 f(n) + g(n) = theta(n^2) 还是不可能?假设 f(n) = theta(n^2) & g(n) = O(n^2) 我尝试了以下方法:f(n) = O(n^2) &
所以我目前正在尝试计算我拥有的一些数据的 Pearson R 和 p 值。这是通过以下代码完成的: import numpy as np from scipy.stats import pearson
ltree 列的默认排序为文本。示例:我的表 id、parentid 和 wbs 中有 3 列。 ltree 列 - wbs 将 1.1.12, 1.1.1, 1.1.2 存储在不同的行中。按 wbs
我的目标是编写一个程序来计算在 python 中表示数字所需的位数,如果我选择 number = -1 或任何负数,程序不会终止,这是我的代码: number = -1 cnt = 0 while(n
我是一名优秀的程序员,十分优秀!