C語言陣列如何定義起始下標是不是若不定義一般起始下標都是

2021-04-15 12:27:05 字數 3661 閱讀 4083

1樓:陳宗權

c語言陣列無法定義起始下標,只能是從0開始,到(元素個數-1)結束,超越這個範圍就是越界訪問。 c++和c#可以實現自定義起始下標。

2樓:匿名使用者

不論在任何bai程式語言,如果沒du有定義起始zhi下標預設都是從

dao0開始

在c語言中不能自定回義起始下標,要想下答標與陣列元素的序號一一對應只能捨棄第一個儲存空間。

例如 你想要一個能儲存4個元素的陣列,並且要下標和元素序號一一對應,就定義int a[5],a[0]不用,從a[1]開始使用,就能做到一一對應。

其他c語言的定義我不熟悉,不知道能不能自定義起始下標,但是vb裡面是可以的:dim a[1 to n],n換成你想要的數字。

3樓:生活寂寞

規定都是從0開始,你要查那個數,可以指定下標

c語言陣列的下標總是從0開始嗎?

4樓:水水好萌

是的,對陣列a[max](max是一個編譯時可知的值)來說,它的第一個和最後一個元素分別是a[o]和almax-1)。在其它一些語言中,情況可能有所不同,例如在basic語言中陣列a[max]的元素是從a[1]到a[max],在pascal語言中則兩種方式都可行。

注意:a[max]是一個有效的地址,但該地址中的值並不是陣列a的一個元素。

上述這種差別有時會引起混亂,因為當你說「陣列中的第一個元素」時,實際上是指「陣列中下標為。的元素」,這裡的「第一個」的意思和「最後一個」相反。

因為指標和陣列幾乎是相同的,因此你可以定義一個指標,使它可以象一個陣列一樣引用另一個陣列中的所有元素,但引用時前者的下標是從1開始的:

/*don't do this!!*/

int a0[max],

int *a1=a0-1; /*&a0[-1)*/

現在,a0[0]和a1[1)是相同的,而a0[max-1]和a1[max]是相同的。然而,在實際程式設計中不應該這樣做,其原因有以下兩點:

第二,這種方式背離了c語言的常規風格。人們已經習慣了c語言中陣列下標的工作方式,如果你的程式使用了另外一種方式,別人就很難讀懂你的程式,而經過一段時間以後,連你自己都可能很難讀懂這個程式了。

為什麼在c語言定義陣列時下標必須從零開始呢?

5樓:

為了標新立異.

在c出現以前的流行語言,例如fortran 從1開始,algol可以自由定義下標從幾開始.

c語言定義從零開始.

從零開始對使用者來說沒有自由定義好,但編譯器設計簡單.省事.

6樓:張立斌

yxlovemoney mdffeng l_o_o_n_i_e

回答的都很有道理。

在c語言定義陣列時下標必須從幾開始,並不要緊,因為這是系統定義的。

無論從幾開始,我們都要會用,都要用好。

7樓:匿名使用者

這需抄要從陣列的儲存方式上襲解釋了。

定義一個bai陣列時,系統會du分配zhi一塊連續的內

dao存,由陣列名指向該塊記憶體的首地址。

引用某個元素時,首先需要計算該元素的地址(及 陣列名 + 下標),然後根據該地址取到相應儲存單元的內容。

所以,如果希望取陣列的第一個元素,下標必須是0

8樓:匿名使用者

就是這麼規定的,沒為什麼

9樓:匿名使用者

為了方便,不用0的話,反而更復雜。

10樓:匿名使用者

美國人計數一般都從0開始

11樓:匿名使用者

c規定的,沒什麼原因,其他語言定義是從1開始的,只是有點方便

12樓:匿名使用者

就是人要吃

bai飯,為什麼不吃屎du一樣的原因zhi,開個玩笑。

陣列是一段連續的空dao間,要求a[i]就是回求它的地址,然答後找到它。如果從0開始,則a[i]的地址= 首地址 + i*每個資料所佔的長度;如果從1開始,則a[i]的地址= 首地址 + (i-1)*每個資料所佔的長度。

那樣從0開始就更易於計算。

不過真正的還是要問其作者才知道具體意義

為什麼c語言的陣列下標從0開始而不是從1開始

13樓:匿名使用者

一種約定。

如果最初約定從1開始 那也沒什麼

至於為什麼會選擇從0開始,最重要的原因 我覺得是方便對於任意的a[i] 取值的時候 都是等效於*(a+i)a是陣列首地址,這樣訪問第一個元素 *(a+0) 就不需要任何偏移了。

c語言的下標為什麼從0開始

14樓:甜心乳酪

其實從0開始是有一定道理的。

陣列是一段連續的空間,要求a[i]就是求它的地址,然後找到它。如果從0開始,則a[i]的地址= 首地址 + i*每個資料所佔的長度;如果從1開始,則a[i]的地址= 首地址 + (i-1)*每個資料所佔的長度。

是不是前一種更好計算呢。

如果是二維陣列就更是這樣了。

15樓:匿名使用者

沒有規定一定要從「0」開始啊,如果你願意,可以從任何數字開始,也能達到一樣的效果。

不過按照人們的習慣,做加法計算的時候,初值都選用「0」(這樣,加幾減幾都不會出現偏差);做乘法運算的時候,初值都選用「1」(如果選用「0」的話,乘到最後的結果就只能是「0」不會得到預期的結果了)。

16樓:手機使用者

和計算機內部的資料結構相關

用二進位制第一個是0

17樓:匿名使用者

學了多維陣列後還不明白這個問題嗎?c語言的這個特徵是很方便的,

18樓:匿名使用者

基本上程式語言的下標都是從0開始的,這可能跟現實中有點兒不一樣..不過慢慢習慣了就好了...^_^

19樓:

vb裡要說option base 1 下標才從1開始啊

我感覺樓上的說的對

20樓:匿名使用者

硬性規定啊!

將來你要能搞出一套開發環境來,下標想從幾開始就從幾開始,你自己規定,別人服從!

21樓:匿名使用者

從幾開始不都一樣,只是個標記而已,也可以從'a'開始,從100開始,習慣了就好了。

22樓:

mlt2004說得好

為什麼陣列下標要從0開始

23樓:匿名使用者

一個陣列的基地址是該陣列的第一個元素地址,沒有要求

說下標必須從零開始,他們可以從任何一個數開始,只要是連續的就可以,但是起始下標是零比較方便討論,因此我們一般都讓陣列從下標零開始,除非有很好的理由不這麼做。

24樓:匿名使用者

好計算地址偏移,你要是懂c語言就比較明白了。

25樓:匿名使用者

c語言的編譯器說從陣列從第0個開始,c語言就從第0個開始了。

26樓:

matlab中陣列下標從1開始

C語言陣列下標,C語言陣列的下標

下標可以是變數 也可以是常量。直接說a 0 a 1 a 2 a 3 這樣的下標就是常量。對於訪問來說,不在意是變數還是常量,系統只是需要一個值,作為偏移量 不管是變數還是常量,訪問的時候 肯定是一個特定值,而系統要的 無非是這樣一個偏移量而已。c語言陣列的下標 樓主你好。注意a是常量,不要被別人誤導...

c語言二維陣列下標表示方法,C語言二維陣列下標表示方法

下標就是在裡的,他是重0開頭的。具體表示如下 int a 5 5代表a最後個陣列裡的元素個數 是初學者吧!要努力喲!int n float a n n 都是從0開始到n 1 c語言二維陣列下標的值怎麼算 陣列的下標是從0開始,由於陣列是連續儲存的,你可以想象用一個4x4的 來表達這個陣列,然後把fo...

c語言自定義的函式如何返回陣列,c語言自定義的函式如何返回一個陣列

方法1 利用全域性變數 分析 全域性變數作為c語言的一個知識點,雖然我們都瞭解它的特點,但在實際教學過程中應用得並不是很多。由於全域性變數的作用域是從定義變數開始直到程式結束,而對於編寫有多個返回值的c語言函式,我們可以考慮把要返回的多個值定義成全域性變數。當函式被呼叫時,全域性變數被更改,我們再把...