C語言支持一維數(shù)組和多維數(shù)組。如果一個數(shù)組的所有元素都不是數(shù)組,那么該數(shù)組稱為一維數(shù)組。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名注冊、虛擬空間、營銷軟件、網(wǎng)站建設(shè)、盧氏網(wǎng)站維護、網(wǎng)站推廣。
在C語言中使用數(shù)組必須先進行定義,一維數(shù)組的定義方式為:類型說明符; 數(shù)組名 ;[常量表達式]。
其中,類型說明符是任一種基本數(shù)據(jù)類型或構(gòu)造數(shù)據(jù)類型。數(shù)組名是用戶定義的數(shù)組標(biāo)識符,方括號中的常量表達式表示數(shù)據(jù)元素的個數(shù),也稱為數(shù)組的長度。例如:
int a[10]; ?/* 說明整型數(shù)組a,有10個元素 */
float b[10], c[20]; ?/* 說明實型數(shù)組b,有10個元素,實型數(shù)組c,有20個元素 */
char ch[20]; ?/* 說明字符數(shù)組ch,有20個元素 */
對于數(shù)組類型說明應(yīng)注意以下幾點:
1、數(shù)組的類型實際上是指數(shù)組元素的取值類型。對于同一個數(shù)組,其所有元素的數(shù)據(jù)類型都是相同的。
2、數(shù)組名的書寫規(guī)則應(yīng)符合標(biāo)識符的書寫規(guī)定。
3、數(shù)組名不能與其它變量名相同。例如:
int a;
float a[10];
是錯誤的。
4、方括號中常量表達式表示數(shù)組元素的個數(shù),如a[5]表示數(shù)組a有5個元素。但是其下標(biāo)從0開始計算。因此5個元素分別為a[0], a[1], a[2], a[3], a[4]。
5、不能在方括號中用變量來表示元素的個數(shù),但是可以是符號常數(shù)或常量表達式。例如:
#define FD 5
// ...
int a[3+2],b[7+FD];
是合法的。但是下述說明方式是錯誤的。
int n=5;
int a[n];
6、允許在同一個類型說明中,說明多個數(shù)組和多個變量。例如:
int a,b,c,d,k1[10],k2[20];
擴展資料:
C語言是一門通用計算機編程語言,廣泛應(yīng)用于底層開發(fā)。C語言的設(shè)計目標(biāo)是提供一種能以簡易的方式編譯、處理低級存儲器、產(chǎn)生少量的機器碼以及不需要任何運行環(huán)境支持便能運行的編程語言。
盡管C語言提供了許多低級處理的功能,但仍然保持著良好跨平臺的特性,以一個標(biāo)準規(guī)格寫出的C語言程序可在許多電腦平臺上進行編譯,甚至包含一些嵌入式處理器(單片機或稱MCU)以及超級電腦等作業(yè)平臺。
二十世紀八十年代,為了避免各開發(fā)廠商用的C語言語法產(chǎn)生差異,由美國國家標(biāo)準局為C語言制定了一套完整的美國國家標(biāo)準語法,稱為ANSI C,作為C語言最初的標(biāo)準。[1]目前2011年12月8日,國際標(biāo)準化組織(ISO)和國際電工委員會(IEC)發(fā)布的C11標(biāo)準是C語言的第三個官方標(biāo)準,也是C語言的最新標(biāo)準,該標(biāo)準更好的支持了漢字函數(shù)名和漢字標(biāo)識符,一定程度上實現(xiàn)了漢字編程。
C語言是一門面向過程的計算機編程語言,與C++,Java等面向?qū)ο蟮木幊陶Z言有所不同。
其編譯器主要有Clang、GCC、WIN-TC、SUBLIME、MSVC、Turbo C等。
C語言中,同變量一樣;數(shù)組也必須先定義后使用。
一維數(shù)組的定義形式:
類型標(biāo)識符? 數(shù)組名[常量表達式];例如int a[10]; ? 其中a為地址常量。
如變量的定義一樣,int a ;double a;float a等;數(shù)組的定義只是把后面的變量名改為數(shù)組名而已。
int a[10]就是定義了一個數(shù)組名為a的數(shù)組;此數(shù)組有10個元素。其中各元素從a[0]到a[9];并沒有a[10]元素。下面列舉一個。
擴展資料
常量表達式可以包括字面常量和符號常量;但不能包含變量。例如對下面定義是錯誤的
int n=5
int a[n]
可以修改為
#define N 5
int a[N]
其中對二維及多位數(shù)組定義可以類推
int? a[x][y][z][...]其中 x,y,z為數(shù)字。
參考資料
百度百科-C語言
C語言支持定義一個不顯式定義長度的數(shù)組,即通過初始化數(shù)據(jù)來分配數(shù)組長度。
比如int a[] = {1,2,3,4,5}; 數(shù)組a的長度沒有顯式給出,由于有5個初始化數(shù)據(jù),所以分配空間長度為5個int型。
但是無論如何定義,數(shù)組的長度都是固定的,在定義的時候就已經(jīng)分配好空間,從這個角度上C語言無法定義無限長的數(shù)組。但很多實際應(yīng)用中又事先無法確定數(shù)組的長度,對于這類情況,一般有兩種方法可以使用。
1 由malloc和realloc兩個函數(shù),分配動態(tài)空間,隨時按需改變數(shù)組的最大長度。
通過下面例子來理解該方法:
#include?stdio.h
#include?stdlib.h
int?main()
{
int?size=100;//最初為100個元素空間。
int?*a?=?NULL;
int?i?=?0;
a?=?malloc(sizeof(int)?*?size);
if(a?==?NULL)?return?-1;
while(scanf("%d",?a+i)?==?1)//循環(huán)向a中輸入數(shù)據(jù),直到輸入非數(shù)值字符為止
{
i++;
if(i?==?size)//數(shù)組空間不足
{
size?*=2;?//將數(shù)組空間擴大二倍,?也可以改用size+=100;之類的操作,使size每次增加固定值。
a=realloc(a,size);//分配新的空間
if(a==NULL)
{
return?-1;//這種情況下運行載體(如PC)內(nèi)存不足以提供,中斷程序。
}
}
}
if(a)?free(a);//對申請的內(nèi)存進行釋放。
return?0;
}
從以上程序可以看到,這種方式的原理就是每當(dāng)數(shù)組空間不足時,利用函數(shù)realloc分配一段新的內(nèi)存空間以增大數(shù)組長度。 直到占滿所有剩余空間。
如果到占滿所有空間還是無法存下數(shù)據(jù),那么是硬件無法支持了。
所以這種方法可以做到軟件意義上的無限大數(shù)組空間。
但是這種方法代碼量比較大,而且需要頻繁的進行內(nèi)存的分配,如果實現(xiàn)知道數(shù)據(jù)的最大可能規(guī)模,那么可以用另一個方法。
2 事先知道數(shù)據(jù)的最大規(guī)模,比如統(tǒng)計一個班的分數(shù)時,一個班最多不超過百人,那么可以直接定義一個長度為100的數(shù)組,或者保險起見,定義一個長度為1000的數(shù)組,并對其操作。這樣在操作范圍內(nèi),這個就是一個“無限長”的數(shù)組了。