1、二維數組的定義:當數組中每個元素帶有兩個下標時,稱這樣的數組為二維數組。在邏輯上可以把二維數組看成是一個具有行和列的表格或一個矩陣。 一般形式:類型說明符 數組名[常量表達式1][常量表達式2]; 例:定義a為3*4(3行4列)的數組,b為5*10(5行10列)的數組。 在記憶體中的表達: 例如: ...
1、二維數組的定義:當數組中每個元素帶有兩個下標時,稱這樣的數組為二維數組。在邏輯上可以把二維數組看成是一個具有行和列的表格或一個矩陣。
一般形式:類型說明符 數組名[常量表達式1][常量表達式2];
例:定義a為3*4(3行4列)的數組,b為5*10(5行10列)的數組。
#include <stdafx.h> #include<stdio.h> void main() { float a[3][4],b[5][10]; }
在記憶體中的表達:
例如:int a[3][4];說明瞭一個三行四列的數組,數組名為a,其下標變數的類型為整型,該數組的下標變數共有3*4個。即:
a[0][0], a[0][1], a[0][2], a[0][3]
a[1][0], a[1][1], a[1][2], a[1][3]
a[2][0], a[2][1], a[2][2], a[2][3]
在C語言中可以把一個二維數組看成是一個一維數組,每個數組元素又是包含有若幹個元素的一維數組。如以上a數組可以看成是由a[0]、a[1]、a[2]三個元素組成的一維數組,其中每個元素又是由四個整型元素組成的一維數組。建立起這一概念是十分重要的,因為C語言編譯系統確實是把二維數組a中的a[0]、a[1]、a[2]作為數組名來處理的。
二維數組在概念上是二維的,但是,實際的硬體存儲器卻是連續編址的,也就是說存儲器單元是按一維線性排列的。
如何在一維存儲器中存放二維數組,有兩種方式:一種是按行排列,即放完一行後順次放入第二行。另一種是按列排列,即放完一列後再順次放入第二列。在C語言中,二維數組是按行排列的。
衍生:多維數組的定義
定義三維數組:float a[2][3][4];
多維數組在記憶體中的排列:第一維的下標變化最慢,最右邊的下標變換最快。
(圖百度的=-=)2、二維數組的引用和初始化
形式:數據類型 數組名[常量表達式1][常量表達式2]={初始化數據};
二維數組的初始化有四種方式:
(1)所賦初值個數與數組元素的個數相同
可以在定義二維數組的同時給二維數組的各元素賦初值。
例如:int a[4][3]={{1,2,3},{4,5,6}{7,8,9},{10,11,12}};
全部初值括在一對花括弧中,之間用逗號隔開。
(2)每行所賦初值個數與數組元素個數不同
當某行一對花括弧內的初值個數少於該行中元素的個數時,如:
int a[4][3]={{1,2},{4,5},{7},{10}};
系統將自動給該行後面的元素補初值0。因此,a[0][2]、a[2][1]的初值為0。也就是說,不能跳過每行前面元素二給後面的元素賦初值。
(3)所賦初值行數少於數組行數
當代表著給每行賦初值的行花括弧對少於數組的行數時,如:
int a[4][3]={{1,2},{4,5}};
系統將自動給後面各行的元素補初值0。
(4)賦初值時省略行花括弧對
在給二維數組賦初值時可以不使用行花括弧對,如:
int a[4][3]={1,2,3,4,5}
系統將按a數組元素在記憶體中的排列順序,將花括弧中的數據一一對應的賦給各元素,若數據不足,系統將給後面的元素自動補初值0。
註:如果對全部元素都賦初值,則定義數組時對第一維的長度可以不指定,但第二維的長度則不能省。
例:int a[3][4]={1,2,3,4,5,6,7,8,9,10,11,12}; 等價於 int a[][4]={1,2,3,4,5,6,7,8,9,10,11,12};
在定義時可以只對部分元素賦初值而省略第一維長度,但應分行賦初值。
例:int a[][4]={{0,0,3},{},{0,10}};
不建議使用