. Patch-Array

PHPz
Freigeben: 2024-07-17 19:19:22
Original
1107 Leute haben es durchsucht

. Patching Array

330. Patch-Array

Schwer

Angenommen ein sortiertes Ganzzahl-Array nums und eine Ganzzahl n, fügen Sie dem Array Elemente hinzu bzw. fügen Sie Elemente hinzu, sodass jede Zahl im Bereich einschließlich [1, n] durch die Summe einiger Elemente im Array gebildet werden kann.

Geben Sie die erforderliche Mindestanzahl an Patches zurück.

Beispiel 1:

  • Eingabe: nums = [1,3], n = 6
  • Ausgabe: 1
  • Erklärung:
    • Zahlenkombinationen sind [1], [3], [1,3], die mögliche Summen von 1, 3, 4 bilden.
    • Wenn wir nun 2 zu Zahlen hinzufügen/patchen, sind die Kombinationen: [1], [2], [3], [1,3], [2,3], [1,2,3].
    • Mögliche Summen sind 1, 2, 3, 4, 5, 6, was nun den Bereich [1, 6] abdeckt.
    • Wir brauchen also nur 1 Patch.

Beispiel 2:

  • Eingabe: nums = [1,5,10], n = 20
  • Ausgabe: 2
  • Erklärung:Die beiden Patches können [2, 4] sein.

Beispiel 3:

  • Eingabe: nums = [1,2,2], n = 5
  • Ausgabe: 0

Einschränkungen:

  • 1 <= nums.length <= 1000
  • 1 <= nums[i] <= 104
  • Die Nummern werden in aufsteigender Reihenfolge sortiert.
  • 1 <= n <= 231 - 1

Lösung:

class Solution {

    /**
     * @param Integer[] $nums
     * @param Integer $n
     * @return Integer
     */
    function minPatches($nums, $n) {
        $ans = 0;
        $i = 0;
        $miss = 1;
         while ($miss <= $n) {
            if ($i < count($nums) && $nums[$i] <= $miss) {
                $miss += $nums[$i++];
            } else {
                $miss += $miss;
                ++$ans;
            }
        }
        return $ans;
    }
}
Nach dem Login kopieren

Kontaktlinks

  • LinkedIn
  • GitHub

Das obige ist der detaillierte Inhalt von. Patch-Array. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
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