„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Dynamische Arrays implementieren

Dynamische Arrays implementieren

Veröffentlicht am 31.07.2024
Durchsuche:485

Implementing Dynamic Arrays

Setzt Verständnis der Big-O-Notation voraus. Beispiele sind in JavaScript. Informationsreferenzen „Cracking the Coding Interview“ von Gayle Laakmann McDowell

Einführung

In einigen Sprachen wie JavaScript oder Python kann die Größe von Arrays automatisch geändert werden, was bedeutet, dass sie größer werden, wenn Sie Elemente anhängen. In anderen Sprachen wie Java haben Arrays feste Längen, was bedeutet, dass die Größe definiert wird, wenn Sie das Array initialisieren. Diese automatisch wachsenden Arrays werden als dynamische Arrays bezeichnet.

Dynamische Arrays verstehen

In Java ist eine ArrayList eine Array-ähnliche Datenstruktur, die eine dynamische Größenänderung ermöglicht und gleichzeitig bereitstellt. O(1)O(1) O(1) Zugang. Wenn das Array voll ist, verdoppelt sich seine Größe. Jede Verdoppelung dauert O(n)O(n) An) Zeit, kommt aber so selten vor, dass die amortisierte Einfügezeit immer noch beträgt O(1)O(1) O(1) .

Unter verschiedenen Programmiersprachen variieren der Name dieser Datenstruktur sowie ihr Größenänderungsfaktor (der in Java 2 beträgt). Der Größenänderungsfaktor bestimmt, um wie viel größer die Größe eines Arrays geändert wird.

Warum handelt es sich um amortisierte Einfügezeit? O(1)O(1) O(1) ?

Wenn wir die Größe ändern und davon ausgehen, dass der Größenänderungsfaktor 2 ist, können wir beobachten, dass wir durch Verdoppelung des vorherigen Arrays (das die Hälfte von N ist) auf ein Array der Größe N anwachsen. Darüber hinaus müssen wir auch kopieren N/2N/2N/2 Elemente zu diesem neuen Array hinzufügen.

Wenn wir die Anzahl der Elemente summieren, die wir von der letzten Kapazitätserhöhung zur ersten Kapazitätserhöhung kopieren: n2 n4 n8 n 16 ... 2 1\frac{n}{2} \frac{n}{4} \frac{n}{8} \frac{n}{16 } ... 2 12n 4n 8 n 16n ... 2 1 was knapp weniger als N ergibt. Daher dauert das Einfügen von N Elementen etwa O(n)O(n) An) insgesamt arbeiten. Jede Einfügung ist O(1)O(1) O(1) im Durchschnitt, auch wenn einige Einfügungen dauern O(n)O(n) An) Zeit im schlimmsten Fall.

Kernkonzepte und Big-O-Komplexität

Dynamische Arrays in JavaScript verfügen normalerweise über mehrere Kernmethoden mit jeweils unterschiedlicher Zeitkomplexität:

get(i): Diese Methode ruft das Element am Index i ab.

  • Komplexität: O(1)O(1) O(1)

set(i, n): Diese Methode setzt das Element am Index i auf n.

  • Komplexität: O(1)O(1) O(1)

pushback(n): Diese Methode fügt das Element n am Ende des Arrays hinzu.

  • Komplexität: O(1)O(1) O(1) amortisiert, aber O(n)O(n) An) wenn eine Größenänderung erfolgt

popback(): Diese Methode entfernt das letzte Element des Arrays.

  • Komplexität: O(1)O(1) O(1)

resize(): Diese Methode verdoppelt die Kapazität des Arrays und kopiert alle Elemente in das neue Array.

  • Komplexität: O(n)O(n) An)

getSize(): Diese Methode gibt die Anzahl der Elemente im Array zurück.

  • Komplexität: O(1)O(1) O(1)
  • Hinweis: Wir können diese Komplexität erreichen, indem wir eine Größenvariable verwenden, um die Anzahl der gefüllten Slots im Array zu verfolgen.

getCapacity(): Diese Methode gibt die aktuelle Kapazität des Arrays zurück.

  • Komplexität: O(1)O(1) O(1)

Implementierung in JavaScript

class DynamicArray {
    // size is # of filled slots while capacity is total slots in array
    constructor(capacity) {
        this.capacity = capacity;
        this.arr = new Array(this.capacity);
        this.size = 0;
    }

    // O(1)
    get(i) {
        if (i = this.size) return undefined;
        return this.arr[i];
    }

    // O(1)
    set(i, n) {
        if (i = this.size) return undefined;
        this.arr[i] = n;
    }

    // O(1) amortized 
    pushback(n) {
        if (this.size === this.capacity) {
            this.resize();
        }
        this.arr[this.size] = n;
        this.size  ;
    }

    // O(1) 
    popback() {
        if (this.size === 0) return undefined;
        this.size--;
        let temp = this.arr[this.size];
        this.arr[this.size] = undefined;
        return temp;

    }

    // O(n)
    resize() {
        this.capacity *= 2;
        let newArr = new Array(this.capacity);
        for (let i = 0; i 



Abschluss

Dynamische Arrays sind eine leistungsstarke Datenstruktur, die die Flexibilität eines skalierbaren Speichers mit der Effizienz eines zeitkonstanten Zugriffs kombiniert. Hoffe das hilft!

Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/jihoonj/implementing-dynamic-arrays-5fb5?1 Bei Verstößen wenden Sie sich bitte an [email protected], um ihn zu löschen
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3