高效實現動態數組

一、什麼是動態數組

動態數組是一種可以在運行時根據需要擴展或縮小大小的數組結構。相較於靜態數組,動態數組具有更高的靈活性。

在C++中,我們可以使用STL中的vector來實現動態數組。

二、使用vector的基本操作

C++ STL中的vector是一個動態數組,提供了方便的操作方法。

1. 定義vector

#include 
using namespace std;

vector vec; //定義一個空的整型vector
vector vec(size); //定義一個有size個元素的整型vector

2. 添加元素

我們可以使用push_back()或insert()函數來添加元素。

vec.push_back(1); //在vector的尾部添加元素1
vec.insert(vec.begin()+index, 1); //在vector的指定位置添加元素1,index表示位置

3. 刪除元素

我們可以使用erase()函數來刪除元素。

vec.erase(vec.begin()+index); //刪除vector的指定位置元素,index表示位置

4. 訪問元素

我們可以使用下標操作符[]、at()函數或迭代器訪問vector中的元素。

vec[index]; //通過下標訪問vector中的元素
vec.at(index); //通過at()函數訪問vector中的元素
for (auto it=vec.begin(); it!=vec.end(); ++it) //通過迭代器訪問vector中的元素
    cout << *it << " ";
cout << endl;

5. 獲取vector大小

我們可以使用size()函數獲取vector中元素的數量。

vec.size(); //獲取vector中元素的個數

三、自定義動態數組

除了使用STL中的vector,我們也可以手動實現動態數組。

1. 實現原理

動態數組可以理解為一個靜態數組加上一個計數器。當靜態數組存儲空間不足時,我們可以使用new運算符動態申請更多的空間,並將舊數據複製到新空間中。

2. 實現代碼

以下是一個簡單的動態數組實現:

template 
class Array {
private:
    T* data; //指向數據的指針
    int size; //數組中元素的數量
    int capacity; //數組中可以存儲的元素數量

public:
    Array(int cap=10) : size(0), capacity(cap) { //構造函數
        data = new T[capacity];
    }

    ~Array() { //析構函數
        delete[] data;
    }

    void resize(int new_cap) { //調整數組大小
        T* new_data = new T[new_cap];
        for (int i=0; i= capacity) {
            resize(2*capacity); //如果存儲空間滿了,擴大空間
        }
        data[size++] = elem;
    }

    void insert(T elem, int index) { //在指定位置插入元素
        if (size >= capacity) {
            resize(2*capacity); //如果存儲空間滿了,擴大空間
        }
        for (int i=size; i>index; --i) {
            data[i] = data[i-1]; //元素後移
        }
        data[index] = elem;
        ++size;
    }

    void erase(int index) { //刪除指定位置的元素
        for (int i=index+1; i<size; ++i) {
            data[i-1] = data[i]; //元素前移
        }
        --size;
        if (size <= capacity/4) {
            resize(capacity/2); //如果存儲空間過多,縮小空間
        }
    }

    T operator[](int index) { //重載下標操作符
        return data[index];
    }

    int getSize() { //獲取數組中元素數量
        return size;
    }
};

四、動態數組的優缺點

1. 優點

動態數組的大小是動態可變的,可以根據需要靈活調整。

動態數組支持尾部添加元素的高效操作,相較鏈表,具有更高的內存緩存優化效果。

2. 缺點

動態數組的調整操作需要消耗一定的時間,刪除操作可能會導致數組空間浪費,增加空間時可能分配不到連續的內存塊。

五、總結

本文介紹了如何使用STL中的vector來實現動態數組,以及手動實現動態數組的基本原理和代碼示例。動態數組相較於靜態數組具有更高的靈活性和操作效率,但也存在空間浪費等問題。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/237130.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:03
下一篇 2024-12-12 12:03

相關推薦

  • QML 動態加載實踐

    探討 QML 框架下動態加載實現的方法和技巧。 一、實現動態加載的方法 QML 支持從 JavaScript 中動態指定需要加載的 QML 組件,並放置到運行時指定的位置。這種技術…

    編程 2025-04-29
  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • Python去掉數組的中括號

    在Python中,被中括號包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括號。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python愛心代碼動態

    本文將從多個方面詳細闡述Python愛心代碼動態,包括實現基本原理、應用場景、代碼示例等。 一、實現基本原理 Python愛心代碼動態使用turtle模塊實現。在繪製一個心形的基礎…

    編程 2025-04-29
  • Python二維數組對齊輸出

    本文將從多個方面詳細闡述Python二維數組對齊輸出的方法與技巧。 一、格式化輸出 Python中提供了格式化輸出的方法,可以對輸出的字符串進行格式化處理。 names = [‘A…

    編程 2025-04-29
  • Java創建一個有10萬個元素的數組

    本文將從以下方面對Java創建一個有10萬個元素的數組進行詳細闡述: 一、基本介紹 Java是一種面向對象的編程語言,其強大的數組功能可以支持創建大規模的多維數組以及各種複雜的數據…

    編程 2025-04-28
  • Python數組隨機分組用法介紹

    Python數組隨機分組是一個在數據分析與處理中常用的技術,它可以將一個大的數據集分成若干組,以便於進行處理和分析。本文將從多個方面對Python數組隨機分組進行詳細的闡述,包括使…

    編程 2025-04-28
  • Python數組索引位置用法介紹

    Python是一門多用途的編程語言,它有着非常強大的數據處理能力。數組是其中一個非常重要的數據類型之一。Python支持多種方式來操作數組的索引位置,我們可以從以下幾個方面對Pyt…

    編程 2025-04-28

發表回復

登錄後才能評論