請哪位大蝦幫忙回答一下C語言中二維陣列是怎麼在記憶體中儲存的

2021-04-21 10:02:09 字數 5863 閱讀 5431

1樓:匿名使用者

呵呵,a[i]存的是a[i][j]的首地址,a[i]+j=&a[i][j].儲存在記憶體什麼區域自己程式設計輸出看看就知道了。

2樓:匿名使用者

不管陣列是幾維的,在記憶體裡都是連續排放的。

例如a[2][2] 就是"a00""a01""a10""a11"的順序

3樓:匿名使用者

簡單地說,c / c++語言中bai的多維陣列,從du語法上到意義zhi上,到機器的

dao內部表示,都是數內組的數容組。

如:int array[5][8];

array是含有5個以(整數陣列int subarray[8])為元素的陣列。這裡只要注意語句宣告的優先順序,是與運算子的優先順序一致的。這種分析方法在c語言中是通用的。

由於陣列本身是連續儲存的,因此按這種分析方式,記憶體中陣列是大地按行、小地按列(行中位)連續儲存的。

其實理解c語言中的陣列只要理解c語言下的計算機記憶體模型就可以了,也不一定非得明確具體在機器上的實現。記憶體模型還是比真實的機器簡單許多的。

4樓:未龍何然

囉唆了。二維陣列的定義方法只要定了列數就行了。像三行四列的陣列,可以說a[3][4],也可以說a[4]。

在記憶體肯定是按順序排著12個數,a[0][0],a[0][1]......

5樓:湯為長

a[i][j]中二維陣列 a[i]可直接表示的是首地址。

a[i][j]是在其後的連續排列的數。

c語言問題:c語言中二維陣列在記憶體中怎樣儲存?

6樓:匿名使用者

嚴格意義上說不存在copy二維bai陣列,只是陣列裡的每du個元素是一個一zhi維陣列,而記憶體是一段連續dao的空間,根據你申請一個變數的順序按地址從低到高排,所以二維陣列不可能像一個矩陣那樣在記憶體中排列,這就涉及到它是按行依次往下排,還是按列往下排,而在c++中是按行,既 int a[2][2]

a[0][0]

a[0][1]

a[1][0]

a[1][1]

7樓:匿名使用者

嚴格意義上說不存在二維陣列,只是陣列裡的每個元素是一個一維陣列,而記憶體是

專一段連續的空間屬,根據你申請一個變數的順序按地址從低到高排,所以二維陣列不可能像一個矩陣那樣在記憶體中排列,這就涉及到它是按行依次往下排,還是按列往下排,而在c++中是按行,既 int a[2][2]

a[0][0]

a[0][1]

a[1][0]

a[1][1]

8樓:匿名使用者

在c/c++中多維數bai組都是以行的形式連du續地分佈在記憶體中的,zhi來個例子dao:

int a[2][2];

則其在記憶體中內

的表現方式為:

a[0][0], 低地址

容a[0][1],

a[1][0],

a[1][1],高地址

9樓:匿名使用者

指向一維陣列的指標陣列。

c語言中二維陣列在記憶體中是按什麼優先存放的?

10樓:二蛋的哥哥哥

c語言中

二維陣列是按行優先儲存的

即 在記憶體中存一個二維陣列時 先把陣列中第一行的陣列元素存完 再接著存下一行的 直到存完。

ps:定義一個二維陣列 如 int a[m][n] 該陣列為m行 n列的矩陣,在記憶體中 這樣順序存的:

a[0][0] a[0][1] ... a[0][n-1] a[1][0] a[1][1]...

不知道是不是幫到你的忙瞭望採納

11樓:匿名使用者

比如a[2][3];的存放順序是:

a[0][0] a[0][1] a[0][2] a[1][0] a[1][1] a[1][2]

12樓:米呀你

c語言陣列是行優先的

在c語言中,二維陣列元素在記憶體中的存放順序是____。(

13樓:非常可愛

在c語言裡二維陣列元素在記憶體中是按行存放的。

二維陣列a[m][n],這是一個m行,n列的二維陣列。設a[p][q]為a的第一個元素,即二維陣列的行下標從p到m+p,列下標從q到n+q,按「行優先順序」儲存時則元素a[i][j]的地址計算為:

loc(a[i][j]) = loc(a[p][q]) + ((i − p) * n + (j − q)) * t;

按「列優先順序」儲存時,地址計算為:

loc(a[i][j]) = loc(a[p][q]) + ((j − q) * m + (i − p)) * t;

存放該陣列至少需要的單元數為(m-p+1) * (n-q+1) * t 個位元組。

擴充套件資料

c++動態二維陣列:

以整形為例,row為行數,col為列數

int **data;//儲存二維陣列的指標(指向指標的指標。date=x[0][0]的地址。這樣標會更好。因為sizeof(date)結果為4不可能存下二維陣列)。

//以下實現如何申請記憶體

data = new int *[row];

for (int k = 0; k < row; k++)

//賦值跟普通二維陣列一樣 例如

data[0][0] = 5; //將二維陣列1行1列(c++中稱為0行0列)賦值為5

//刪除記憶體

for (int i = 0 ; i < row; ++i)

delete data;

14樓:進理秦剛捷

自己用vc++6.0作了測試,**如下:

輸出結果如下:

可見,此二維陣列在記憶體中按照如下順序存放:

a[0][0]

a[0][1]

a[1][0]

a[1][1]

a[2][0]

a[2][1]

15樓:匿名使用者

在c語言中,二維陣列元素在記憶體中的存放順序是(按行存放)即在記憶體中線順序存放第一行的元素,再存放第二行的元素。

16樓:友人改變自己

在c語言中,二維陣列元素在記憶體中的存放順序是 先行後列

在c語言中,二維陣列元素在記憶體中的存放順序是 a按行存放 b按列存放 c由使用者自己定義 d由編譯器決定

17樓:鬱筱羽

二維陣列在記憶體中按行存放。

二維陣列在c語言中的定義為:int a[x][y]。具體理解為二維陣列a,有x行資料,每行資料有y個。

解釋:當我們在進行資料的存取時,在無x的條件下不可能取出值。但是在沒有y的條件下,可以通過地址取出x行的某個值。

當我們知道x的值,代表我們能確定這一行的首地址,因為二維陣列按照行存放,所以第x行的資料地址關係排列遞增的。

反證法:如果二維陣列按列存放,則我們知道y值,可以確定首地址的值,去進行值得存取。顯然由於c語言不支援這樣的方式,所以c語言中二維陣列按照行存放。

18樓:喵星球的大橘

c語言中,二維陣列

元素在記憶體中是按行存放的。

二維陣列本質上是以陣列作為陣列元素的陣列,即「陣列的陣列」,型別說明符 陣列名[常量表示式][常量表示式]。二維陣列在概念上是二維的,即是說其下標在兩個方向上變化, 下標變數在陣列中的位置也處於一個平面之中, 而不是象一維陣列只是一個向量。

但是,實際的硬體儲存器卻是連續編址的, 也就是說儲存器單元是按一維線性排列的。如何在一維儲存器中存放二維陣列,可有兩種方式:一種是按行排列, 即放完一行之後順次放入第二行。

另一種是按列排列, 即放完一列之後再順次放入第二列。在c語言中,二維陣列是按行排列的。

例如:float a[3][4],b[5][10];     定義a為3*4(3行4列)的陣列,b為5*10(5行10列)的陣列。注意,不能寫成 float a[3,4],b[5,10];  具體可以表示:

a[3][4]=,, }

擴充套件資料:

1、表示方法:

陣列元素也是一種變數, 其標識方法為陣列名後跟一個下標。下標表示了元素在陣列中的順序號。陣列元素的一般形式為:

陣列名[下標] 其中的下標只能為整型常量或整型表示式。如為小數時,c編譯將自動取整。例如,a[5],a[i+j],a[i++]都是合法的陣列元素。

陣列元素通常也稱為下標變數。必須先定義陣列, 才能使用下標變數。

2、賦值方法:

初始化賦值的一般形式為:static型別說明符陣列名[常量表示式]=; 其中static表示是靜態儲存型別, c語言規定只有靜態儲存陣列和外部儲存陣列才可作初始化賦值。在中的各資料值即為各元素的初值, 各值之間用逗號間隔。

例如:static int a[10]=; 相當於a[0]=0;a[1]=1...a[9]=9;

3、使用規則:

一、陣列的型別實際上是指陣列元素的取值型別。對於同一個陣列,其所有元素的資料型別都是相同的。

二、陣列名的書寫規則應符合識別符號的書寫規定。

三、陣列名不能與其它變數名相同。

四、可以只給部分元素賦初值。當中值的個數少於元素個數時,只給前面部分元素賦值。例如:

static int a[10]=;表示只給a[0]~a[4]5個元素賦值,而後5個元素自動賦0值。

五、只能給元素逐個賦值,不能給陣列整體賦值。例如給十個元素全部賦1值,只能寫為:static int a[10]=;而不能寫為:

static int a[10]=1;(請注意:在c、c#語言中是這樣,但並非在所有涉及陣列的地方都這樣,資料庫是從1開始。)

六、若不給可初始化的陣列賦初值,則全部元素均為0值。

七、假如給全部元素賦值,則在陣列說明中, 可以不給出陣列元素的個數。例如:static int a[5]=;  可寫為:

static int a=;動態賦值可以在程式執行過程中,對陣列作動態賦值。這時可用迴圈語句配合scanf函式逐個對陣列元素賦值。

19樓:匿名使用者

答案為a。

關於c語言中的陣列存放順序是這樣的:

假設有陣列如下:

int x=;

char ca[5]=;

陣列名即代表陣列的地址,陣列的地址==陣列名(ca)==陣列的首元素的地址&ca[0]

在記憶體中,記憶體從大到小進行定址,為陣列分配了儲存空間後,陣列的元素自然的從上往下排列儲存,整個陣列的地址為首元素的地址。

模擬該陣列的記憶體儲存細節如下:

注意:字元在記憶體中是以對應ascii值的二進位制形式儲存的,而非上表的形式。

在這個例子中,陣列x的地址為它的首元素的地址0x08,陣列ca的地址為0x03。

在二維陣列中a[y][x],其中x下標表示的是行,y下標表示的是列,而看上圖,是以x下標為優先順序儲存的,因此,答案是a:按行存放。

20樓:匿名使用者

#include

int main(),};

for (int i = 0; i < 2; i++)}return 0;

}輸出結果:

a[0][0] 的地址

0028fef8

a[0][1] 的地址 0028fefc

a[1][0] 的地址 0028ff00

a[1][1] 的地址 0028ff04

process returned 0 (0x0) execution time : 0.657 s

press any key to continue.

懂了嗎?

幫忙回答一下,幫忙回答一下?

假設一共收集了x箇舊電池 根據收集的數量大於30小於40 所以,x在30和40之間 又因為x能被五整除 所以x 35 一共收集了35節舊電池 這個題目,答案簡單,為了幫你正確理解答案,分析如下 二 1 班的電池數量是在 40和30之間 40 二 1 班的電池數量 30 二 1 電池數量能被5整除 因...

請問一下C語言中,printfc是c這一列的作用是什麼?可以詳細解釋下嗎

printf c 是一個bai c 這句話就 是說你從鍵盤du輸入的字元zhi c是一個 數字或者什麼的dao 根回據你後面的判斷才顯示,答那條語句只是一個簡單的輸出語句,c跟後面的c是對應的,c是輸出一個字元,你定義的c是字元型別。有什麼問題可以繼續問我哦!a 是一個小寫字母 輸出結果是這種樣子。...

急,幫忙回答一下,急!!知道的幫忙回答一下?

問他以前都幹嘛,以前有男朋友麼 你首先問 我是你的初戀嗎?然後再問我是你的初吻嗎?然後在問我是你的第一夜嗎?逐步引出話來 望採納 問一問,她的第一次感覺怎麼樣 委婉點問她你是她的第幾任然後看她性格什麼樣 自己感覺 這得看你和她有多好的關係,好的話可以直接問 急!知道的幫忙回答一下?不查便罷了,查到沒...