數組:只能存放一種數據類型,比如int類型的數組、float類型的數組,里面存放的數據稱為“元素”。
數組的定義:
首先聲明數組的類型,然后聲明數組元素的個數,也就是定義需要多少存儲空間。
數組格式與初始化
格式:
元素類型 數組名[元素個數];
比如:
int[3];
數組元素有順序之分,每個元素都有一個唯一的下標(索引),而且都是從0開始。
數組中第i個元素的訪問方式:
a[i]
數組元素的初始化:
int a[3] = {10, 9, 6}; int a[3] = {10,9}; int a[] = {11, 7, 6}; int a[4] = {[1]=11,[0] = 7};
[ ]里面的個數必須是一個固定值,可以是常量(比如6、8)、常量表達式(比如3+4、5*7)。絕對不能使用變量或者變量表達式來表示元素個數,大多數情況下不要省略元素個數,當數組作為函數的形參和數組初始化時除外。
C語言中編譯器是不會對數組下標越界進行檢查的,所以自己訪問數組元素時要注意。
一維數組
數組的內存細節分析
#includeint main() { charcs[5]={'a','A','D','e','f'}; printf("%p ",cs);//數組名就代表數組的地址 for (int i = 0; i<5; i++) { printf("cs[%d]的地址是:%p ",i ,&cs[i]); ????} return 0; }
上面代碼中,地址分配分析如下:
一維數組的元素作為函數實參,與同類型的簡單變量作為實參一樣,是單向的值傳遞,即數組元素的值傳給形參,從而形參是改變不影響實參。
數組名代表著整個數組的地址,如果一維數組的名字作為函數實參,傳遞的是整個數組,即形參數組和實參數組完全相同,是存放在同一存儲空間的同一個數組。這樣形參數組修改時,實參數組也同時被修改了。形參數組的元素個數可以省略。
// b是test函數的形參(形式參數) void test(int b) { b = 9; } int main() { int a[3]; a[0]=10; printf("函數調用前的a[0]:%d ",a[0]); test(a[0]);//a[0]是test函數的實參(實際參數) printf("函數調用后的a[0]:%d", a[0]); return 0; }
#include//數組作為函數參數,可以省略元素個數 //數組作為函數參數,傳遞是整個數組的地址,修改了函數形參數組元素的值,會影響到外面的實參數組 void change(int array[]) { printf("array==%p ",array); array[0] = 100; } int main() { intages[6]={10,11,13,15,11,18}; printf("array==%p ",ages); change(ages); printf("%d ",ages[0]); return0; }
輸出結果為:
array==0x7fff5be26c00 array ==0x7fff5be26c00 100
數組的小練習,找最大值:
/* 設計一個函數,找出整型數組元素的最大值 */ #includeint maxOfArray(int array[], int length) { // 數組當做函數參數傳遞時,會當做指針變量來使用,指針變量在64bit編譯器環境下,占據8個字節 //int size = sizeof(array); //printf("array=%d ", size); //sizeof(array); // 1.定義一個變量存儲最大值(默認就是首元素) int max = array[0]; // 2.遍歷所有元素,找出最大值 for (int i = 1; i max) { max = array[i]; } } return max; } int main() { int ages[] = {11, 90, 67, 150, 78, 60, 70, 89, 100}; int ages2[] = {11, 90, 67, 150, 78, 60, 70, 89, 100}; //int size = sizeof(ages); //printf("ages=%d ", size); int max = maxOfArray(ages, sizeof(ages)/sizeof(int)); printf("%d ", max); return 0; }
二維數組
一個數組能表示一個班人的年齡,如果想表示很多班呢?
什么是二維數組?int ages[3][10]; 三個班,每個班10個人,相當于3行10列,相當于裝著3個一維數組。
二維數組是一個特殊的一維數組:它的元素是一維數組。例如int a[2][3]可以看作由一維數組a[0]和一維數組a[1]組成,這兩個一維數組都包含了3個int類型的元素。
定義形式:
類型 數組名[ 行數] [列數]
int a[2][3]; //2行3列的二維數組
二維數組的存放順序是按行存放的,先存放第一行的元素,再存放第2行的元素。例如int a[2][3]的存放順序是:
a[0][0] → a[0][1] → a[0][2] → a[1][0] → a[1][1] → a[1][2]
二維數組的內存存儲分配
注意:a[0]、a[1]也是數組,是一維數組,而且a[0]、a[1]就是數組名,因此a[0]、a[1]就代表著這個一維數組的地址。
數組a的地址是ffc1,數組a[0]的地址也是ffc1,即a = a[0]
元素a[0][0]的地址是ffc1,所以數組a[0]的地址和元素a[0][0]的地址相同,即a[0] = &a[0][0]
最終可以得出結論:a = a[0] = &a[0][0],以此類推,可以得出a[1] = &a[1][0]
二維數組的初始化:
intages2[3][5]={ {10,11,90,89,70}, {10,11,90,89,70}, {10, 11, 90, 89, 70} };
審核編輯:彭菁
-
存儲
+關注
關注
13文章
4499瀏覽量
87059 -
C語言
+關注
關注
180文章
7630瀏覽量
140220 -
元素
+關注
關注
0文章
47瀏覽量
8581 -
數組
+關注
關注
1文章
419瀏覽量
26364
原文標題:總結C語言中的數組知識點
文章出處:【微信號:單片機與嵌入式,微信公眾號:單片機與嵌入式】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
【原創分享】變量的初始化技巧
c語言二維數組初始化及使用

19-C語言中的數組知識匯總
C語言中指針與數組

C語言指定初始化器解析及其應用

評論