c語言可變數(shù)組的實現(xiàn) c語言數(shù)組名值可變嗎?
c語言數(shù)組名值可變嗎?以前版本的C99沒有。數(shù)組大小必須是常量或常量表達(dá)式。C99版本只添加了一個可變長度數(shù)組我不會查看冒泡排序的算法部分,直接告訴您不知道錯誤的原因。你的第一種寫作方式:int n=
c語言數(shù)組名值可變嗎?
以前版本的C99沒有。數(shù)組大小必須是常量或常量表達(dá)式。C99版本只添加了一個可變長度數(shù)組
我不會查看冒泡排序的算法部分,直接告訴您不知道錯誤的原因。你的第一種寫作方式:int n=1,a[n],I=0,j=0,k=0。這里定義了n=1,在這一行中還定義了[n]。然后編譯器將在這里直接為序列a分配內(nèi)存。也就是說,確定陣列A的大小,即1。我不知道你是否學(xué)會了內(nèi)存分配。我給你一個簡短的解釋。您可以在線搜索詳細(xì)信息。例如,一個具有五種整數(shù)類型的數(shù)組可以定義為[5],但也可以按如下方式獲得:int*a=(int*)malloc(sizeof(int)*5)也就是說,我們將內(nèi)存分配給一個指針以獲得一個數(shù)組。[5]的定義還要求編譯器在編譯程序時分配內(nèi)存。編譯器將根據(jù)您的代碼優(yōu)化您的程序,并將代碼轉(zhuǎn)換為匯編代碼。另外,機器代碼說得太多了。我將繼續(xù)分析修改后的代碼int n=1,I=0,j=0,K=0printf(“please input the length of the array:”)scanf(%d“,&n)int a[n];//此時,由于您在聲明數(shù)組之前讀入了n,因此a是根據(jù)您輸入的數(shù)字確定的數(shù)組大小。你知道我的意思嗎?
C語言,可變長數(shù)組?
指針自增自減
第四個空標(biāo)題不清楚:
數(shù)組名代表它的第一個地址
數(shù)組名本身只有一個存儲地址,所以第一個地址沒有問題
要保存數(shù)組的第一個地址,您需要使用指向指針的指針
如果數(shù)組名是a
則鍵入**a=&A
數(shù)字組的大小不能用變量表示,因為編譯和連接時必須根據(jù)您的系統(tǒng)控制內(nèi)存設(shè)置數(shù)組的長度來分配相應(yīng)的內(nèi)存空間,如果它是一個變量,那么就沒有辦法分配它了,可以用符號常量來求解,首先用:
#define m 100
#define N 100,然后在程序中可以定義u[m][N]二維數(shù)組,當(dāng)不一定是100時,可以是任意正整數(shù)。
在C語言中,所有變量空間在程序運行開始時應(yīng)用于系統(tǒng),包括和指針。它也需要空間,除了一些動態(tài)應(yīng)用程序方法,如malloc函數(shù)。未經(jīng)申請,不得在航天系統(tǒng)中進行讀寫操作。然后,如果數(shù)組的大小是一個變量定義,則在程序運行之前無法確定數(shù)組的大小,因此無法應(yīng)用它,因此不允許這樣做。解決方案如前所述,例如:int a[n
]可以更改為
int*const a=(int*)malloc(sizeof(int)*n)
,這樣變量就可以直接用作數(shù)組,包括[1]。因為“[]”中的方括號運算符只偏移其中的地址數(shù)并取一個值。例如,
a[1
]相當(dāng)于
*(a 1)
,星號后的常量修飾符表示指針聲明后不能更改,即只能指向獲取的空間,完全符合數(shù)組的性質(zhì)。
如果必須直接,只需交換指針即可。例如:將LG數(shù)組復(fù)制到CHS數(shù)組:
long LG[20];
byte CHS[200];
CHS=(char*)&lg[0];
這是直接的。記住,一定要用指針。
其次,可以使用memcpy函數(shù)來解決問題。
函數(shù)原型為void*memcpy(void*目的地,void*源,無符號n)。該函數(shù)將源內(nèi)存地址開頭的幾個字節(jié)復(fù)制到目標(biāo)內(nèi)存地址,即從源內(nèi)存地址復(fù)制n個字節(jié)到目標(biāo)內(nèi)存地址。
希望對您有所幫助。