vector二維數組的詳解

vector是C++ STL庫中非常常用的容器之一,它的特點是動態分配內存,可以根據實際情況自動擴容。而二維數組則是一個由多個一維數組組成的數組,可以看成是一個表格,具有行列的性質。在本文中,我們將結合vector和二維數組的特點,對vector二維數組進行詳細的闡述。

一、創建vector二維數組

vector二維數組是一個元素也為vector的一維數組,因此我們可以通過vector的構造函數和push_back()函數來創建vector二維數組。

1、使用構造函數創建

vector<vector<int>> matrix(m, vector<int>(n));

上述代碼中,我們使用了vector的構造函數,它可以指定vector的大小和默認值,第一個參數是行數m,第二個參數是一個vector,代表一行,第二個參數的大小是列數n。這樣我們就創建了一個大小為m * n的vector二維數組。

2、使用push_back()函數動態添加元素

vector<vector<int>> matrix;
for(int i = 0; i < m; i++){
    vector<int> row;
    for(int j = 0; j < n; j++){
        row.push_back(0);
    }
    matrix.push_back(row);
}

上述代碼中,我們使用了vector的push_back()函數,首先我們創建了一個空的vector二維數組matrix,然後通過for循環逐行逐列添加元素。在添加一行元素時,我們創建了一個空的vector row,並通過for循環向其中逐個添加元素0。最後將row添加到matrix中,就完成了一行的添加。重複該操作m次,則可得到一個大小為m * n的vector二維數組。

二、訪問vector二維數組中的元素

由於vector二維數組本質上是一個普通的二維數組,所以我們可以通過雙重循環來訪問其中的元素。

1、使用下標訪問元素

for(int i = 0; i < m; i++){
    for(int j = 0; j < n; j++){
        matrix[i][j] = i * j;
    }
}

上述代碼中,我們通過雙重循環將矩陣中的元素初始化為其坐標的乘積。這裡使用了vector二維數組的下標訪問方法,類似於普通的二維數組。

2、使用迭代器訪問元素

for(vector<vector<int>>::iterator it = matrix.begin(); it != matrix.end(); it++){
    for(vector<int>::iterator jt = (*it).begin(); jt != (*it).end(); jt++){
        *jt = 1;
    }
}

上述代碼中,我們通過雙重for循環,使用迭代器訪問vector二維數組中的元素。需要注意的是,二維數組的每個元素都是vector類型,因此外層循環的迭代器類型為vector<vector>::iterator,而內層循環的迭代器類型為vector::iterator。

三、vector二維數組的一些常用操作

1、插入一行或一列

vector<int> new_row(n, 0);
matrix.insert(matrix.begin() + pos, new_row);  //插入一行

for(int i = 0; i < m; i++){
    matrix[i].insert(matrix[i].begin() + pos, 0);  //插入一列
}

上述代碼中,我們使用了vector的insert()函數來插入一行或一列,參數中需要指定位置和插入的元素。

2、刪除一行或一列

matrix.erase(matrix.begin() + pos);  //刪除一行

for(int i = 0; i < m; i++){
    matrix[i].erase(matrix[i].begin() + pos);  //刪除一列
}

上述代碼中,我們使用了vector的erase()函數來刪除一行或一列,參數中需要指定位置。

3、獲取行數和列數

int m = matrix.size();  //獲取行數

if(m > 0){
    int n = matrix[0].size();  //獲取列數
}

上述代碼中,我們使用了vector的size()函數來獲取行數和列數。需要注意的是,由於vector二維數組中的每行都是一個vector,因此我們可以通過任意一行來獲取列數。

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
SJPZJ的頭像SJPZJ
上一篇 2025-02-24 00:34
下一篇 2025-02-24 00:34

相關推薦

  • 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中提供了格式化輸出的方法,可以對輸出的字元串進行格式化處理。 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
  • Python語言數組從大到小排序符號的用法介紹

    當我們使用Python進行編程的時候,經常需要對數組進行排序從而使數組更加有序,而數組的排序方式有很多,其中從大到小排序符號是一種常見的排序方式。本文將從多個方面對Python語言…

    編程 2025-04-28
  • Python列錶轉numpy數組

    本文將闡述Python中列表如何轉換成numpy數組。在科學計算和數據分析領域中,numpy數組扮演著重要的角色。Python與numpy的無縫結合使得數據操作更加方便和高效。因此…

    編程 2025-04-27

發表回復

登錄後才能評論