Sie erhalten eine nicht leere Liste mit positiven ganzen Zahlen, z
[6 2 9 7 2 6 5 3 3 4]
Sie sollten diese Zahlen nach ihrem Wert ordnen, aber wie in Ranglisten üblich, erhalten bei einem Gleichstand alle verbundenen Zahlen den gleichen Rang, und eine entsprechende Anzahl von Rängen wird übersprungen. Die erwartete Ausgabe für die obige Liste wäre daher
[3 9 1 2 9 3 5 7 7 6]
Beispielsweise war der höchste Wert in der Eingabe 9
, so dass dies ein 1
(erster Rang) wird. Der dritthöchste Wert ist 6
, so dass beide 6
s worden 3
, und der Rang 4
ist komplett übersprungen.
Regeln
Sie können jedes bequeme, eindeutige, flache Listenformat für die Eingabe und Ausgabe verwenden. Der erste / kleinste Rang in der Ausgabe sollte immer 1 sein .
Du darfst schreiben a Programm oder eine Funktion unserer Standardmethoden zum Empfangen und Bereitstellen von Eingaben verwenden.
Sie können jede verwenden Programmiersprache verwenden , beachten Sie jedoch, dass diese Lücken standardmäßig verboten sind.
Das ist Code-Golf , also gewinnt die kürzeste gültige Antwort - gemessen in Bytes .
Testfälle
[8] -> [1]
[1 15] -> [2 1]
[18 14 11] -> [1 2 3]
[11 16 14 8] -> [3 1 2 4]
[15 15 15 15 15] -> [1 1 1 1 1]
[10 2 5 4 15 5] -> [2 6 3 5 1 3]
[5 5 10 10 5 11 18] -> [5 5 3 3 5 2 1]
[2 4 9 4 17 9 17 16] -> [8 6 4 6 1 4 1 3]
[11 17 19 17 10 10 15 3 18] -> [6 3 1 3 7 7 5 9 2]
[2 11 4 8 3 3 12 20 4 18] -> [10 4 6 5 8 8 3 1 6 2]
[12 6 10 2 19 19 6 19 8 6 18] -> [5 8 6 11 1 1 8 1 7 8 4]
[5 6 14 19 13 5 19 9 19 9 9 19] -> [11 10 5 1 6 11 1 7 1 7 7 1]
[9 2 12 3 7 11 15 11 6 8 11 17 11] -> [8 13 3 12 10 4 2 4 11 9 4 1 4]
[3 5 15 7 18 5 3 9 11 2 18 1 10 19] -> [11 9 4 8 2 9 11 7 5 13 2 14 6 1]
[6 11 4 19 14 7 13 16 10 12 7 9 7 10 10] -> [14 6 15 1 3 11 4 2 7 5 11 10 11 7 7]
[11 20 11 1 20 16 11 11 4 8 9 7 11 14 10 14] -> [6 1 6 16 1 3 6 6 15 13 12 14 6 4 11 4]
[4 7 15 2 3 2 3 1 14 2 10 4 7 6 11 2 18] -> [9 6 2 13 11 13 11 17 3 13 5 9 6 8 4 13 1]
[5 1 17 7 1 9 3 6 9 7 6 3 2 18 14 4 18 16] -> [12 17 3 8 17 6 14 10 6 8 10 14 16 1 5 13 1 4]
[5 6 8 10 18 13 20 10 7 1 8 19 20 10 10 18 7 2 1] -> [16 15 11 7 4 6 1 7 13 18 11 3 1 7 7 4 13 17 18]
[12 17 8 2 9 7 15 6 19 5 13 16 14 20 10 11 18 4 3 1] -> [9 4 13 19 12 14 6 15 2 16 8 5 7 1 11 10 3 17 18 20]
indexOf
Funktionsform beruhen . Ich glaube, für unsortierte Eingaben gibt es in vielen Sprachen kürzere Alternativen.