js implementiert den Algorithmus zur Angabe der Reihenfolge und Menge der roten Umschläge

js implementiert den Algorithmus zur Angabe der Reihenfolge und Menge der roten Umschläge

In diesem Artikel wird der spezifische JS-Code zur Implementierung der angegebenen roten Umschlagreihenfolge und des angegebenen Betrags zu Ihrer Information veröffentlicht. Der spezifische Inhalt ist wie folgt

Vorwort

  • Geschrieben auf Wunsch eines Freundes
  • Der Mindestbetrag für ein einzelnes Paket beträgt 0,01
  • Wenn alle anderen Werte außer dem angegebenen Betrag 0,01 sind, beträgt die Wahrscheinlichkeit, dass das letzte Paket 0 ist
  • Dieser Algorithmus hat 1.000.000 Tests mit einer Fehlerrate von 3 pro Million bestanden

Effektanzeige

Problem mit leeren Paketen

Red-Envelope-Algorithmus

/*
    Parameter: Float, Int, Int, Float
    Param1: Gesamtmenge der roten Umschläge Param2: Anzahl der roten Umschläge Param3: Geben Sie spezielle rote Umschläge an Param4: Geben Sie die Menge spezieller roter Umschläge an*/
let getPrize = Funktion(Gesamt, Zahl, Index, Volumen){
    sei Zulage = Gesamt - Volumen;

    sei arr = [];
    sei i = 0;
    während(i < Zahl - 2){
        //Geben Sie [0,01, Toleranz-(i*0,01)) an.
        let temp = (Math.random()*(Zulässigkeit - (Zahl - 1 - i) * 0,01) + 0,01).toFixed(2);
        // wenn (temp < 0) console.log(`temp:${temp}`);
        Temp = Temp <= 0? 0,01: Temp;        
        arr.push(parseFloat(temp));
        Zulage = parseFloat((Zulage - temp).toFixed(2));        
        ich++;
        // console.log(`arr:${arr}, i:${i}`);
        // Wenn die Verteilung kleiner als 0 ist, nutze die Stärke aus und teile sie gleichmäßig auf, wenn (Zuschuss <= 0) {
            // console.log(`allowance:${allowance}`);
            
            
            sei w = arr.filter((val,index)=>{
                // console.log(`val:${val}`);
                wenn(Wert > 0,01){
                    
                    arr[index] = parseFloat((arr[index] - 0,01).toFixed(2));
                    Rückgabewert;
                }
            });

            wenn(w.Länge == 0){
                Zulage = 0;
            }anders{
                Zulage = 0,01;
            }
            
        }
    }
    // Der letzte wird in arr.push(parseFloat(allowance.toFixed(2))); eingefügt.
    lass Ergebnis = arr;

    gibt Ergebnis.Slice(0, Index).concat(parseFloat(Volumen), Ergebnis.Slice(Index)) zurück;
}

Testbeispiele

// Testbeispiel
für(lass m = 0; m < 10000; m++){
    sei total = (Math.random()*100 + 0,01).toFixed(2);

    lass Zahl = Math.floor(Math.random()*20 +2);
    während(Gesamt / Zahl < 0,01){
        Zahl = Math.floor(Math.random()*20 +2);
    }

    let index = Math.floor(Math.random()*(Zahl - 1));

    lass Volumen = (Math.random()*(Gesamt - 0,01*(Zahl-1))+0,01).toFixed(2);
    während(Volumen >= Gesamt || Volumen + 0,01*(Zahl-1) > Gesamt){
        // konsole.log(`xx:${volume}`);
        Volumen = (Math.random()*(Gesamt - 0,01*(Zahl-1))+0,01).toFixed(2);
        Volumen = Volumen <= 0? 0,01: Volumen;
    }
    
    
    let test = getPrize(Gesamt, Zahl, Index, Volumen);
    // konsole.log(test);
    Lassen Sie Summe = test.reduce((total,val)=>total+=parseFloat(val));
    Summe = Summe.toFixed(2);
    wenn(Summe !== Gesamt) {
        console.log(`Volumen: ${Volumen}, Gesamt: ${Total}, Zahl: ${Zahl}`);
        Konsole.log(`Summe: ${Summe}`);
        Konsole.log(Test);
    }
    test.map((Wert,Index)=>{
        wenn(Wert <= 0 && Index !== Testlänge - 1){
            console.log(`Volumen: ${Volumen}, Gesamt: ${Total}, Zahl: ${Zahl}`);
            Konsole.log(`Summe: ${Summe}`);
            Konsole.log(Test);
        }
    });

}

Das Obige ist der vollständige Inhalt dieses Artikels. Ich hoffe, er wird für jedermanns Studium hilfreich sein. Ich hoffe auch, dass jeder 123WORDPRESS.COM unterstützen wird.

Das könnte Sie auch interessieren:
  • Verwenden von JS zum Implementieren von Beispielcode für den Algorithmus zur binären Baumdurchquerung
  • So verwenden Sie JavaScript zum Implementieren von Sortieralgorithmen
  • JavaScript-Programmierung durch Lernen der Positionierung des Schwerpunktalgorithmus in Matlab
  • Tutorial zum binären Suchbaumalgorithmus für JavaScript-Anfänger
  • Zusammenfassung von sieben in JavaScript implementierten Sortieralgorithmen (empfohlen!)
  • Eine kurze Diskussion über einen effizienten Algorithmus zum Erstellen von Baumstrukturen in JavaScript
  • So lernen Sie algorithmische Komplexität mit JavaScript
  • So verwenden Sie Javascript zum Erstellen einfacher Algorithmen

<<:  Eine kurze Diskussion über die Effizienz der MySQL-Unterabfrage-Vereinigung und in

>>:  Beispiel für die Verwendung des Supervisors zum Verwalten von Nginx+Tomcat-Containern

Artikel empfehlen

Wie füge ich ein Website-Symbol hinzu?

Der erste Schritt besteht darin, eine Software zur...

TinyEditor ist ein einfacher und benutzerfreundlicher HTML-WYSIWYG-Editor

Vor einigen Tagen habe ich Ihnen einen inländisch...

Implementierung von Platzhaltern und Escape-Zeichen in der Linux-Befehlszeile

Wenn wir Stapeloperationen für einen Dateityp aus...

Node.js gibt je nach Anforderungspfad unterschiedliche Daten zurück.

Inhaltsverzeichnis 1. Lernen Sie, je nach Anforde...

So ändern Sie den Standardzeichensatz von MySQL auf dem MAC auf UTF-8

1. Überprüfen Sie den Zeichensatz des standardmäß...

Bereinigungsmethode für das Docker-Verzeichnis /var/lib/docker/aufs/mnt

Der Dienst des Unternehmens verwendet Docker und ...

Drei Möglichkeiten zum Sperren und Entsperren von Benutzerkonten in Linux

Wenn in Ihrer Organisation bereits eine Kennwortr...

Schritte zur vollständigen Deinstallation des Docker-Images

1. docker ps -a zeigt den laufenden Image-Prozess...

Implementierung des CSS-Quellcodes für herzförmige Ladeanimationen

Lassen Sie mich Ihnen ohne weitere Umschweife den...

Anfänger verstehen das MySQL-Deadlock-Problem anhand des Quellcodes

Nach vielen schwierigen Einzelschritt-Debuggings ...

Einige Tipps zur richtigen Verwendung des HTML-Titelattributs

Wenn Sie Inhalte vor Benutzern von Telefonen, Tabl...