C 數組


C 語言支援陣列資料結構,它可以儲存一個固定大小的相同類型元素的順序集合。數組是用來儲存一系列數據,但它往往被認為是一系列相同類型的變數。

數組的宣告並不是宣告一個個單獨的變量,例如number0、number1、...、number99,而是宣告一個數組變量,例如numbers,然後使用numbers[0]、numbers[1] 、...、numbers[99] 來代表一個個單獨的變數。數組中的特定元素可以透過索引存取。

所有的陣列都是由連續的記憶體位置組成。最低的位址對應第一個元素,最高的位址對應最後一個元素。

1050.jpg
#

宣告數組

在 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。以下是上面所討論的陣列的的圖形表示:

1051.jpg

存取陣列元素

#陣列元素可以透過陣列名稱加索引進行存取。元素的索引是放在方括號內,跟在陣列名稱的後邊。例如:

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 程式設計師必須清楚的一些與陣列相關的重要概念:

C 支援多維數組。多維數組最簡單的形式是二維數組。 您可以透過指定不帶索引的陣列名稱來給函數傳遞一個指向陣列的指標。 C 允許從函數傳回陣列。
#描述
多維數組
傳遞陣列給函數
從函數傳回陣列
###指向陣列的指標######您可以透過指定不帶索引的陣列名稱來產生一個指向陣列中第一個元素的指標。 ################