Heim > Web-Frontend > js-Tutorial > Hauptteil

Lustige JavaScript-Frage: Weight Loss Club

黄舟
Freigeben: 2017-02-04 15:24:24
Original
1097 Leute haben es durchsucht

Mein Freund Xiao Wang und ich sind beide Mitglieder des „Weight Loss Fitness Club“.

Xiao Wang wirkte in letzter Zeit immer besorgt, da an diesen Tagen jeden Monat eine Gewichtsliste aller Mitglieder veröffentlicht wird, und er ist ausnahmslos immer der Dickste.

Ich war auch Teil der Liste, also sagte ich zu ihm: „Mach dir keine Sorgen, mein Freund, ich werde dir helfen, die Reihenfolge der Liste zu ändern.“

Nachdem ich darüber nachgedacht hatte, dachte ich, es wäre besser, sie in dieser Reihenfolge anzuordnen: Jede Gewichtszahl wird entsprechend der Summe jeder Ziffer angeordnet, vom kleinsten zum größten.

Zum Beispiel 99 kg, die Summe seiner Ziffern ist 18, was bedeutet, dass das „Gewicht“ 18 ist.

Ein anderes Beispiel: 100 kg haben ein Gewicht von 1, also rangieren sie vor 99 kg.

Die Aufgabe lautet wie folgt:

Können Sie eine Reihe von Mitgliederlisten von Abnehmclubs nach Gewicht sortieren und zurücksenden?

Beispiel:

"56 65 74 100 99 68 86 180 90"  => "100 180 90 56 65 74 68 86 99"
Nach dem Login kopieren

Wenn zwei Zahlen das gleiche Gewicht haben, z. B. 180 und 90, dann steht 180 an erster Stelle. Zu diesem Zeitpunkt folgen wir der Wörterbuchreihenfolge.


Alle Zahlen sind positiv, die Liste ist möglicherweise leer.

Als ich diese Frage sah, war ich ehrlich gesagt etwas verschwitzt ~ Schließlich bin ich auch ein dicker Mann.

Es ist offensichtlich nicht praktisch, Strings direkt zu bedienen, also teilen wir sie in Arrays auf!

Sortieren Sie dann das Array. Die Regeln lauten wie folgt:

1. Dem Gewicht wird Priorität gegeben. Je kleiner das Gewicht, desto höher die Rangfolge.

2. Wenn die Gewichte gleich sind, ordnen Sie sie in der Reihenfolge des Wörterbuchs an.

Um das Gewicht zu berechnen, also die Summe jeder Ziffer, benötigen Sie diese Methode:

function eachDigitSum(num){  
    var sum = 0;  
    num = num - 0;  
    while(num > 0){  
        sum += num % 10;  
        num = parseInt(num / 10);  
    }  
    return sum;  
}
Nach dem Login kopieren

Um dann die lexikografische Reihenfolge zu vergleichen, benötigen Sie diese Methode:

function compareASCII(a,b){  
    var i=0;  
    while(true){  
        var c1 = a.charCodeAt(i);  
        var c2 = b.charCodeAt(i);  
        if(!c1){  
            return -1;  
        }  
        if(!c2){  
            return 1;  
        }  
        if(c1 < c2){  
            return -1;  
        }  
        if(c1 > c2){  
            return 1;  
        }  
        i++;  
    }  
}
Nach dem Login kopieren

Tatsächlich gibt es für diese Methode eine Alternative in nativem JS:

String.prototype.localeCompare
Nach dem Login kopieren

Dies ist standardmäßig die Wörterbuchreihenfolge.


Zum Schluss müssen Sie nur noch in Strings integrieren, sortieren und aggregieren.

function orderWeight(str) {  
    return str.split(" ").sort(function(a,b){  
        var n1 = eachDigitSum(a);  
        var n2 = eachDigitSum(b);  
        if(n1 > n2){  
            return 1;  
        }  
        else if(n1 < n2){  
            return -1;  
        }  
        else{  
            return compareASCII(a,b);  
        }  
    }).join(" ");  
}
Nach dem Login kopieren

Das Obige ist der Inhalt von JavaScript Interessante Fragen: Weight Loss Club Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!


Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!