C 數組
C 語言支援陣列資料結構,它可以儲存一個固定大小的相同類型元素的順序集合。數組是用來儲存一系列數據,但它往往被認為是一系列相同類型的變數。
數組的宣告並不是宣告一個個單獨的變量,例如number0、number1、...、number99,而是宣告一個數組變量,例如numbers,然後使用numbers[0]、numbers[1] 、...、numbers[99] 來代表一個個單獨的變數。數組中的特定元素可以透過索引存取。
所有的陣列都是由連續的記憶體位置組成。最低的位址對應第一個元素,最高的位址對應最後一個元素。
宣告數組
在 C 中要宣告一個數組,需要指定元素的型別和元素的數量,如下所示:
type arrayName [ arraySize ];
這叫做一維數組。 arraySize 必須是一個大於零的整數常數,type 可以是任意有效的 C 資料型別。例如,要宣告一個類型為double 的包含10 個元素的陣列balance,宣告語句如下:
double balance[10];
現在balance 是一個可用的數組,可以容納10 個類型為double 的數字。
初始化數組
在C 中,您可以逐個初始化數組,也可以使用一個初始化語句,如下所示:
double balance[5] = {1000.0, 2.0, 3.4, 7.0, 50.0};
大括號{ } 之間的值的數目不能大於我們在數組宣告時在方括號[ ] 中指定的元素數目。
如果您省略掉了陣列的大小,則陣列的大小則為初始化時元素的數量。因此,如果:
double balance[] = {1000.0, 2.0, 3.4, 7.0, 50.0};
您將建立一個數組,它與前一個實例中所建立的數組是完全相同的。下面是一個為數組中某個元素賦值的實例:
balance[4] = 50.0;
上述的語句把數組中第五個元素的值賦為 50.0。所有的數組都是以 0 作為它們第一個元素的索引,也被稱為基索引,數組的最後一個索引是數組的總大小減去 1。以下是上面所討論的陣列的的圖形表示:
存取陣列元素
#陣列元素可以透過陣列名稱加索引進行存取。元素的索引是放在方括號內,跟在陣列名稱的後邊。例如:
double salary = balance[9];
上面的語句將把陣列中第 10 個元素的值賦給 salary 變數。下面的實例使用了上述的三個概念,即,聲明數組、數組賦值、訪問數組:
#include <stdio.h> int main (){ int n[ 10 ]; /* n 是一个包含 10 个整数的数组 */ int i,j; /* 初始化数组元素 */ for ( i = 0; i < 10; i++ ) { n[ i ] = i + 100; /* 设置元素 i 为 i + 100 */ } /* 输出数组中每个元素的值 */ for (j = 0; j < 10; j++ ) { printf("Element[%d] = %d\n", j, n[j] ); } return 0;}
當上面的程式碼被編譯和執行時,它會產生下列結果:
Element[0] = 100Element[1] = 101Element[2] = 102Element[3] = 103Element[4] = 104Element[5] = 105Element[6] = 106Element[7] = 107Element[8] = 108Element[9] = 109
C 中陣列詳解
在C 中,陣列是非常重要的,我們需要了解更多關於陣列的細節。以下列出了C 程式設計師必須清楚的一些與陣列相關的重要概念:
#描述 | |
---|---|
多維數組 | |
傳遞陣列給函數 | |
從函數傳回陣列 |