国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > C++ > 正文

詳解C++編程中用數(shù)組名作函數(shù)參數(shù)的方法

2020-05-23 14:14:48
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

這篇文章主要介紹了詳解C++編程中用數(shù)組名作函數(shù)參數(shù)的方法,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下

C++數(shù)組的概念

概括地說(shuō):數(shù)組是有序數(shù)據(jù)的集合。要尋找一個(gè)數(shù)組中的某一個(gè)元素必須給出兩個(gè)要素,即數(shù)組名和下標(biāo)。數(shù)組名和下標(biāo)惟一地標(biāo)識(shí)一個(gè)數(shù)組中的一個(gè)元素。

數(shù)組是有類型屬性的。同一數(shù)組中的每一個(gè)元素都必須屬于同一數(shù)據(jù)類型。一個(gè)數(shù)組在內(nèi)存中占一片連續(xù)的存儲(chǔ)單元。如果有一個(gè)整型數(shù)組a,假設(shè)數(shù)組的起始地址為2000,則該數(shù)組在內(nèi)存中的存儲(chǔ)情況如圖所示。

詳解C++編程中用數(shù)組名作函數(shù)參數(shù)的方法

引入數(shù)組就不需要在程序中定義大量的變量,大大減少程序中變量的數(shù)量,使程序精煉,而且數(shù)組含義清楚,使用方便,明確地反映了數(shù)據(jù)間的聯(lián)系。許多好的算法都與數(shù)組有關(guān)。熟練地利用數(shù)組,可以大大地提高編程和解題的效率,加強(qiáng)了程序的可讀性。

C++用方括號(hào)來(lái)表示下標(biāo),如用s[1],s[2],s[3] 分別代表s1,s2,s3。

C++用數(shù)組名作函數(shù)參數(shù)

常量和變量可以用作函數(shù)實(shí)參,同樣數(shù)組元素也可以作函數(shù)實(shí)參,其用法與變量相同。數(shù)組名也可以作實(shí)參和形參,傳遞的是數(shù)組的起始地址。

用數(shù)組元素作函數(shù)實(shí)參

由于實(shí)參可以是表達(dá)式,而數(shù)組元素可以是表達(dá)式的組成部分,因此數(shù)組元素當(dāng)然可以作為函數(shù)的實(shí)參,與用變量作實(shí)參一樣,將數(shù)組元素的值傳送給形參變量。

【例】用函數(shù)處理。

今設(shè)一函數(shù)max_value,用來(lái)進(jìn)行比較并返回結(jié)果。可編寫(xiě)程序如下:

 

 
  1. #include <iostream> 
  2. using namespace std; 
  3. int main( ) 
  4. int max_value(int x,int max); //函數(shù)聲明 
  5. int i,j,row=0,colum=0,max 
  6. int a[3][4]={{5,12,23,56},{19,28,37,46},{-12,-34,6,8}}; //數(shù)組初始化 
  7. max=a[0][0]; 
  8. for (i=0;i<=2;i++) 
  9. for (j=0;j<=3;j++) 
  10. max=max_value(a[i][j],max); //調(diào)用max_value函數(shù) 
  11. if(max==a[i][j])//如果函數(shù)返回的是a[i][j]的值 
  12. row=i; //記下該元素行號(hào)i 
  13. colum=j; //記下該元素列號(hào)j 
  14. cout<<"max="<<max<<",row="<<row<<",colum="<<colum<<endl; 
  15. int max_value(int x,int max)//定義max_value函數(shù) 
  16. if(x>max) return x;//如果x>max,函數(shù)返回值為x 
  17. else return max;//如果x≤max,函數(shù)返回值為max 

用數(shù)組名作函數(shù)參數(shù)

可以用數(shù)組名作函數(shù)參數(shù),此時(shí)實(shí)參與形參都用數(shù)組名(也可以用指針變量,見(jiàn)第6章)。

【例】用選擇法對(duì)數(shù)組中10個(gè)整數(shù)按由小到大排序。

所謂選擇法就是先將10個(gè)數(shù)中最小的數(shù)與a[0]對(duì)換,再將a[1]到a[9]中最小的數(shù)與a[1]對(duì)換……每比較一輪,找出一個(gè)未經(jīng)排序的數(shù)中最小的一個(gè)。共比較9輪。根據(jù)此思路編寫(xiě)程序如下:

 

 
  1. #include <iostream> 
  2. using namespace std; 
  3. int main( ) 
  4. void select_sort(int array[],int n); //函數(shù)聲明 
  5. int a[10],i; 
  6. cout<<"enter the originl array:"<<endl; 
  7. for(i=0;i<10;i++) //輸入10個(gè)數(shù) 
  8. cin>>a[i]; 
  9. cout<<endl; 
  10. select_sort(a,10);//函數(shù)調(diào)用,數(shù)組名作實(shí)參 
  11. cout<<"the sorted array:"<<endl; 
  12. for(i=0;i<10;i++) //輸出10個(gè)已排好序的數(shù) 
  13. cout<<a[i]<<" "
  14. cout<<endl; 
  15. return 0; 
  16. void select_sort(int array[],int n) //形參array是數(shù)組名 
  17. int i,j,k,t; 
  18. for(i=0;i<n-1;i++) 
  19. k=i; 
  20. for(j=i+1;j<n;j++) 
  21. if(array[j]<array[k]) k=j; 
  22. t=array[k];array[k]=array[i];array[i]=t; 

運(yùn)行情況如下:

 

 
  1. enter the originl array: 
  2. 6 9 -2 56 87 11 -54 3 0 77↙ //輸入10個(gè)數(shù) 
  3. the sorted array: 
  4. -54 -2 0 3 6 9 11 56 77 87 

關(guān)于用數(shù)組名作函數(shù)參數(shù)有兩點(diǎn)要說(shuō)明:

1) 如果函數(shù)實(shí)參是數(shù)組名,形參也應(yīng)為數(shù)組名(或指針變量),形參不能聲明為普通變量(如int array;)。實(shí)參數(shù)組與形參數(shù)組類型應(yīng)一致(現(xiàn)都為int型),如不一致,結(jié)果將出錯(cuò)。

2) 需要特別說(shuō)明的是: 數(shù)組名代表數(shù)組首元素的地址,并不代表數(shù)組中的全部元素。因此用數(shù)組名作函數(shù)實(shí)參時(shí),不是把實(shí)參數(shù)組的值傳遞給形參,而只是將實(shí)參數(shù)組首元素的地址傳遞給形參。

形參可以是數(shù)組名,也可以是指針變量,它們用來(lái)接收實(shí)參傳來(lái)的地址。如果形參是數(shù)組名,它代表的是形參數(shù)組首元素的地址。在調(diào)用函數(shù)時(shí),將實(shí)參數(shù)組首元素的地址傳遞給形參數(shù)組名。這樣,實(shí)參數(shù)組和形參數(shù)組就共占同一段內(nèi)存單元。見(jiàn)圖。

詳解C++編程中用數(shù)組名作函數(shù)參數(shù)的方法

在用變量作函數(shù)參數(shù)時(shí),只能將實(shí)參變量的值傳給形參變量,在調(diào)用函數(shù)過(guò)程中如果改變了形參的值,對(duì)實(shí)參沒(méi)有影響,即實(shí)參的值不因形參的值改變而改變。而用數(shù)組名作函數(shù)實(shí)參時(shí),改變形參數(shù)組元素的值將同時(shí)改變實(shí)參數(shù)組元素的值。在程序設(shè)計(jì)中往往有意識(shí)地利用這一特點(diǎn)改變實(shí)參數(shù)組元素的值。

實(shí)際上,聲明形參數(shù)組并不意味著真正建立一個(gè)包含若干元素的數(shù)組,在調(diào)用函數(shù)時(shí)也不對(duì)它分配存儲(chǔ)單元,只是用array[]這樣的形式表示array是一維數(shù)組名,以接收實(shí)參傳來(lái)的地址。因此array[]中方括號(hào)內(nèi)的數(shù)值并無(wú)實(shí)際作用,編譯系統(tǒng)對(duì)一維數(shù)組方括號(hào)內(nèi)的內(nèi)容不予處理。形參一維數(shù)組的聲明中可以寫(xiě)元素個(gè)數(shù),也可以不寫(xiě)。

函數(shù)首部的下面幾種寫(xiě)法都合法,作用相同:

 

 
  1. void select_sort(int array[10],int n) //指定元素個(gè)數(shù)與實(shí)參數(shù)組相同 
  2. void select_sort(int array[],int n) //不指定元素個(gè)數(shù) 
  3. void select_sort(int array[5],int n) //指定元素個(gè)數(shù)與實(shí)參數(shù)組不同 

C++實(shí)際上只把形參數(shù)組名作為一個(gè)指針變量來(lái)處理,用來(lái)接收從實(shí)參傳過(guò)來(lái)的地址。前面提到的一些現(xiàn)象都是由此而產(chǎn)生的。

用多維數(shù)組名作函數(shù)參數(shù)

如果用二維數(shù)組名作為實(shí)參和形參,在對(duì)形參數(shù)組聲明時(shí),必須指定第二維(即列)的大小,且應(yīng)與實(shí)參的第二維的大小相同。第一維的大小可以指定,也可以不指定。如:

 

 
  1. int array[3][10]; //形參數(shù)組的兩個(gè)維都指定 

 

 
  1. int array[][10]; //第一維大小省略 

二者都合法而且等價(jià)。但是不能把第二維的大小省略。下面的形參數(shù)組寫(xiě)法不合法:

 

 
  1. int array[][]; //不能確定數(shù)組的每一行有多少列元素 
  2. int array[3][]; //不指定列數(shù)就無(wú)法確定數(shù)組的結(jié)構(gòu) 

在第二維大小相同的前提下,形參數(shù)組的第一維可以與實(shí)參數(shù)組不同。例如,實(shí)參數(shù)組定義為:

int score[5][10];

而形參數(shù)組可以聲明為:

 

 
  1. int array[3][10]; //列數(shù)與實(shí)參數(shù)組相同,行數(shù)不同 
  2. int array[8][10]; 

這時(shí)形參二維數(shù)組與實(shí)參二維數(shù)組都是由相同類型和大小的一維數(shù)組組成的,實(shí)參數(shù)組名score代表其首元素(即第一行)的起始地址,系統(tǒng)不檢查第一維的大小。

如果是三維或更多維的數(shù)組,處理方法是類似的。

【例】有一個(gè)3×4的矩陣,求矩陣中所有元素中的最大值。要求用函數(shù)處理。

解此題的程序如下:

 

 
  1. #include <iostream> 
  2. using namespace std; 
  3. int main( ) 
  4. int max_value(int array[][4]); 
  5. int a[3][4]={{11,32,45,67},{22,44,66,88},{15,72,43,37}}; 
  6. cout<<"max value is "<<max_value(a)<<endl; 
  7. return 0; 
  8. int max_value(int array[][4]) 
  9. int i,j,max; 
  10. max=array[0][0]; 
  11. for( i=0;i<3;i++) 
  12. for(j=0;j<4;j++) 
  13. if(array[i][j]>max) max=array[i][j]; 
  14. return max; 

運(yùn)行結(jié)果如下:

 

 
  1. max value is 88 

讀者可以將max_value函數(shù)的首部改為以下幾種情況,觀察編譯情況:

 

 
  1. int max_value(int array[][]) 
  2. int max_value(int array[3][]) 
  3. int max_value(int array[3][4]) 
  4. int max_value(int array[10][10]) 
  5. int max_value(int array[12]) 

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 平果县| 麦盖提县| 富顺县| 阿拉善右旗| 三穗县| 芜湖市| 卢湾区| 塔城市| 靖州| 怀仁县| 泰州市| 南澳县| 永兴县| 邛崃市| 襄城县| 汝阳县| 梅河口市| 漾濞| 自治县| 罗田县| 手游| 张家港市| 祁门县| 甘洛县| 吴旗县| 浮山县| 扶绥县| 富川| 太白县| 河西区| 来宾市| 莎车县| 安化县| 托里县| 奉节县| 阿合奇县| 固安县| 台中县| 丰顺县| 石城县| 深水埗区|