この記事では、指定された赤い封筒の順序と金額を実装するためのjsの具体的なコードを共有します。具体的な内容は次のとおりです。 序文
エフェクト表示空パッケージの問題赤い封筒アルゴリズム/* パラメータ: float、int、int、float パラメータ1: 紅封筒の合計金額 パラメータ2: 紅封筒の数 パラメータ3: 特別な紅封筒を指定 パラメータ4: 特別な紅封筒の金額を指定*/ getPrize = function(合計、数、インデックス、ボリューム){ 許容量 = 合計 - 容積とします。 arr = [] とします。 i = 0 とします。 while(i < 数値 - 2){ // [0.01, allowance-(i*0.01)) を指定します temp = (Math.random()*(allowance - (number - 1 - i) * 0.01) + 0.01).toFixed(2) とします。 // temp < 0 の場合 console.log(`temp:${temp}`); 温度 = 温度 <= 0 ? 0.01 : 温度; arr.push(parseFloat(temp)); 許容値 = parseFloat((許容値 - temp).toFixed(2)); 私は++; // console.log(`arr:${arr}, i:${i}`); // 分布が 0 未満の場合は、強い方を利用して均等に分割します if(allowance <= 0){ // console.log(`allowance:${allowance}`); w = arr.filter((val,index)=>{とする // console.log(`val:${val}`); (値>0.01){ arr[インデックス] = parseFloat((arr[インデックス] - 0.01).toFixed(2)); 戻り値: } }); w.length == 0の場合{ 許容量 = 0; }それ以外{ 許容値 = 0.01; } } } // 最後はarr.push(parseFloat(allowance.toFixed(2)));に配置されます。 結果を arr とします。 result.slice(0, index).concat(parseFloat(volume), result.slice(index)); を返します。 } テスト例 // テストサンプル (m = 0; m < 10000; m++){ 合計を(Math.random()*100 + 0.01).toFixed(2)とします。 数値 = Math.floor(Math.random()*20 +2); while(合計 / 数 < 0.01){ 数値 = Math.floor(Math.random()*20 +2); } index = Math.floor(Math.random()*(number - 1))とします。 ボリュームを(Math.random()*(合計 - 0.01*(数値-1))+0.01).toFixed(2)とします。 while(ボリューム >= 合計 || ボリューム + 0.01*(数値-1) > 合計){ // console.log(`xx:${volume}`); 音量 = (Math.random()*(合計 - 0.01*(数値-1))+0.01).toFixed(2); ボリューム = ボリューム <= 0 ? 0.01 : ボリューム; } test = getPrize(合計、数、インデックス、ボリューム); // コンソールログ(テスト); sum = test.reduce((total,val)=>total+=parseFloat(val)); とします。 合計 = sum.toFixed(2); if(合計 !== 合計) { console.log(`ボリューム:${volume}、合計: ${total}、数値: ${number}`); console.log(`sum:${sum}`); コンソールにログ出力します。 } test.map((val,index)=>{ if(val <= 0 && index !== test.length - 1){ console.log(`ボリューム:${volume}、合計: ${total}、数値: ${number}`); console.log(`sum:${sum}`); コンソールにログ出力します。 } }); } 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MySQLのサブクエリユニオンの効率性についての簡単な説明と
>>: スーパーバイザーを使用して nginx + tomcat コンテナを管理する例
ウェブページの基本要素として、画像はページの読み込み速度に影響を与える重要な要素の 1 つです。画像...
特記事項: Swoole 拡張機能のみがインストールされ、サーバーはホストにインストールされません。...
導入2日前に見た問題について詳細に書きます。バイトコンピューターがバイナリに基づいていることは誰もが...
目次0x01 ドライバーモジュールのロードに失敗しました0x02 ソリューション要約する0x01 ド...
この記事では、VueでEchartsをインポートして線散布図を実現する具体的なコードを参考までに共有...
ここ数年、私は自動化とコンピューターを行ったり来たりしてきました。最近は、機械学習に関連するプロジェ...
Zabbix カスタム スクリプトを使用して監視データを収集する場合、通常、次の問題が発生します。サ...
この記事では、バウンドボールゲームを実装するためのjQueryの具体的なコードを参考までに共有します...
この記事の例では、テーブルを追加および削除するためのjsの具体的なコードを参考までに共有しています。...
概要MySQL データベースで主キーのないテーブルを表示するための SQL ステートメントをいくつか...
Apache Tomcat は、Java Servlet および Java Server Pages...
HTML入門ハイパーテキスト マークアップ言語: ハイパーテキスト マークアップ言語ハイパーテキスト...
1. xshell を使用して仮想マシンに接続するか、仮想マシンに直接コマンドを入力します。以下はx...
非準拠データがデータベースに入るのを防ぐために、ユーザーがデータを挿入、変更、削除、その他の操作を行...
目次MySQLクラッシュ回復プロセス1. ブラックボックス下のデータフローを更新する2. やり直しロ...