C++動態數組詳解

一、動態數組概述

動態數組是一種可以動態增加或減少大小的數據結構,它可以根據需要實時改變數組大小。動態數組可以在程序運行時根據需求分配內存,相比於靜態數組,這樣可以更好的控制內存的使用,同時可以減少浪費。

二、動態數組實現原理

實現一個動態數組需要維護一個指針,指向當前動態數組中的內存塊。當數組需要擴容時,程序需要申請一個更大的內存塊,將原有元素複製到新的內存塊中,這時可以將原有內存塊刪除,並將指針指向新的內存塊。在縮小數組大小時,同樣需要按照類似的方式操作。

三、動態數組的優缺點

優點:

1、動態數組可以根據需要實時改變數組大小,可以更好的控制內存的使用。

2、相比於靜態數組,動態數組可以減少浪費。

缺點:

1、動態數組需要額外的內存儲存指針,由於動態數組的增長通常是指數級別的,因此會產生較大的內存開銷。

2、由於動態數組的內存分配不是連續的存儲空間,因此數組元素的訪問效率不如靜態數組高。

四、動態數組實現代碼

#include <iostream>
using namespace std;

class DynamicArray {
private:
  int *pData;//指向動態數組的指針
  int m_size;//動態數組的大小
  int m_nLength;//動態數組的長度

public:
  DynamicArray(int size) 
  {
    m_size = size;
    m_nLength = 0;
    pData = new int[m_size];
  }

  ~DynamicArray(void) 
  {
    delete[] pData;
  }

  void ReSize(int newSize) 
  {
    int *pNewData = new int[newSize];

    memcpy(pNewData, pData, sizeof(int) * m_nLength);

    delete[] pData;

    pData = pNewData;

    m_size = newSize;
  }

  void Add(int element) 
  {
    if (m_nLength == m_size) 
    {
      ReSize(m_size * 2);
    }

    pData[m_nLength++] = element;
  }

  void RemoveAt(int nIndex) 
  {
    if (nIndex >= m_nLength || nIndex < 0) 
    {
      return;
    }

    for (int i = nIndex; i < m_nLength - 1; i++) 
    {
      pData[i] = pData[i + 1];
    }

    m_nLength--;

    if (m_nLength < m_size / 2) 
    {
      ReSize(m_size / 2);
    }
  }
};

五、動態數組的使用示例

我們可以使用上述的動態數組代碼進行測試。

int main() {
  DynamicArray arr(10);
  arr.Add(1);
  arr.Add(2);
  arr.Add(3);
  arr.Add(4);
  arr.Add(5);
  arr.Add(6);

  arr.RemoveAt(3);

  for (int i = 0; i < arr.GetSize(); i++) 
  {
    cout << arr[i] << " ";
  }

  return 0;
}

六、小結

本文詳細介紹了C++動態數組的概念、實現原理、優缺點以及代碼實現。動態數組是一個非常實用的數據結構,可以幫助我們更好的控制內存的使用,管理數據。使用動態數組時,需要注意動態數組的內存開銷和訪問效率。

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
TZJIN的頭像TZJIN
上一篇 2025-01-21 17:30
下一篇 2025-01-21 17:30

相關推薦

  • 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

發表回復

登錄後才能評論