二維數組的存儲
❶ 二維數組元素在內存中的存放順序是
二維數組元素在內存中的存放順序是按行存放。
當進行數據的存取時,在無x的條件下不可能取出值。但是在沒有y的條件下,可以通過地址取出x行的某個值。當知道x的值,代表能確定這一行的首地址,因為二維數組按照行存放,所以第x行的數據地址關系排列遞增的。
如果二維數組按列存放,則知道y值,可以確定首地址的值,去進行值得存取。顯然由於c語言不支持這樣的方式,所以C語言中二維數組按照行存放。
(1)二維數組的存儲擴展閱讀
常用的二維數組的表示方法
第一種是普通的二維數組的表示方法。
第二種是用一維數組來表示二維數組,從顯示的元素地址可以看出,二維數組和一維數組表示的二維數組在內存中的儲存方式其實是一樣的,不過使用二維數組看起來要簡單些,只要不用進行地址轉換。
第三種表示是用指針數組。這種方法對各個元素大小不一樣的情況下比較適用。
第四種方式為用指向指針的變數來表示。此種方式p是指向指針的指針,不能把普通的二維數組的首地址賦給它,可以把第三種方式中的數組指針的首地址賦給它,這種方式用的較少。
❷ 二維數組在內存中是如何存放的
因為你的a[M][N]有12個元素,所以end-begin(即p-a[0])肯定恆為11。因為指針相減的結果是元素差而不是地址差。比如若有int a[3]={1,2,3};則&a[1]-&a[0]=1,而它們的地址值卻相差4。在內存中無論幾維數組,都是按一維數組存放的。比如二維數組,第一行最後一個元素後就緊接著第二行的第一個元素,依此類推。這也是多維數組都可以降維為一維數組來處理的原因。
❸ 在C語言中,二維數組元素在內存中的存放順序是____。(
在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 個位元組。
(3)二維數組的存儲擴展閱讀
C++動態二維數組:
以整形為例,row為行數,col為列數
int **data;//存儲二維數組的指針(指向指針的指針。date=x[0][0]的地址。這樣標會更好。因為sizeof(date)結果為4不可能存下二維數組)。
//以下實現如何申請內存
data = new int *[row];
for (int k = 0; k < row; k++)
{
data[k] = new int[col];
}
//賦值跟普通二維數組一樣 例如
data[0][0] = 5; //將二維數組1行1列(C++中稱為0行0列)賦值為5
//刪除內存
for (int i = 0 ; i < row; ++i)
{
delete [] data[i]; //此處的[]不可省略
}
delete [] data;
❹ 怎麼儲存二維數組
一是在源碼中就給的數值,如
a(1,1) = 1
a(1,2) = 0
a(2,1) = 0
a(2,2) = 1
另外一種是通過外部文件讀取其中數據賦值給數組。
❺ 在C語言中,二維數組數據的存儲形式。不準用百度里的話回答;要用自己的話簡明扼要的回答,而且還要有特點
二維數組分兩種.一是如int arr[10][5];這樣定義的.另一種是用malloc形式定義的.第二種比較復雜一些,你或許暫時不用太了解.第一種的話,一般是連續分配的,按行優先順序或列優先順序對存儲單元進行編號.arr[0][4]後面一個元素就是arr[1][0],就是這個情況.如果是列優先排列的話,arr[9][0]後面一個元素是arr[0][1];一般都實現為前者(行優先).其實就好比把一個數組給折疊起來了.
對於malloc申請的,可能就會是不連續的了.它會要求先申請一個一維數組,裡面存的都是指針,然後為每個指針再申請一個一維數組,這樣就構成了一個二維數組了.這種不保證連續.當然 你也可以手工構造連續的數組空間.那就比較麻煩些了.
❻ 二維數組在內存中是如何存儲的
二維數組在內存中是如何存儲的,這不是一定的,具體要看編譯系統是如何規定的。
對於多數編譯系統而言,都是採用「行優先」的策略,比如一個int a[5][3]數組,它是從首地址開始依次是a[0][0],a[0][1],a[0][2],然後是a[1][0],a[1][1],a[1][2],……。直到最後是a[4][0],a[4][1],a[4][2]。
❼ 我有一個二維數組要存儲到本地,用什麼方式比較好
二維數組A[m][n]可以視為由m個行向量組成的向量,或者是由n個列向量組成的向量。
由於計算機的內存是一維的,多維數組的元素應排成線性序列後存入存儲器。數組一般不做插入和刪除操作,即結構中元素個數和元素間的關系不變。所以採用順序存儲方法表示數組。
1、行優先存儲
將數組元素按行向量排列,第i+1個行向量緊接在第i個行向量後面。
【例】二維數組A[m][n]按行優先存儲的線性序列為:
A[0][0]、A[0][1]…A[0][n]、A[1][1]、A[1][1]…A[1][n]…A[m][n]、A[m][1]…A[m][n]
在PASCAL和C語言中數組按行優先順序存儲。
2、列優先存儲
將數組元素按列向量排列,第i+1個列向量緊接在第i個列向量後面。
【例】二維數組A[m][n]按列優先存儲的線性序列為:
A[0][0]、A[1][0]…A[m][0]、A[0][1]、A[1][1]…A[m][1]…A[m][1]、A[0][n]…A[m][n]
ORTRAN語言中,數組按列優先順序存儲。
❽ 簡要說明二維數組中的每個元素在計算機中是怎麼樣存儲的
二維數組中的每一個元素在計算機當中的內存中都是連續存儲的。具體存儲的格式根據不同的編譯系統,有不一樣的。大多數的編譯系統是仙存儲第一行,第一個元素,然後再存儲第一行的第二個元素,照此類推到第一行的最後一個元素,存儲完成以後再存儲第二二行的第一個元素,直到全部元……
❾ c語言中二維數組在內存中是按什麼優先存放的
C語言中
二維數組是按行優先存儲的
即 在內存中存一個二維數組時 先把數組中第一行的數組元素存完 再接著存下一行的 直到存完。
ps:定義一個二維數組 如 int a[m][n] 該數組為m行 n列的矩陣,在內存中 這樣順序存的:
a[0][0] a[0][1] ... a[0][n-1] a[1][0] a[1][1]...
不知道是不是幫到你的忙了
望採納