詳解C++編程中用數(shù)組名作函數(shù)參數(shù)的方法
C++數(shù)組的概念
概括地說:數(shù)組是有序數(shù)據(jù)的集合。要尋找一個數(shù)組中的某一個元素必須給出兩個要素,即數(shù)組名和下標。數(shù)組名和下標惟一地標識一個數(shù)組中的一個元素。
數(shù)組是有類型屬性的。同一數(shù)組中的每一個元素都必須屬于同一數(shù)據(jù)類型。一個數(shù)組在內(nèi)存中占一片連續(xù)的存儲單元。如果有一個整型數(shù)組a,假設(shè)數(shù)組的起始地址為2000,則該數(shù)組在內(nèi)存中的存儲情況如圖所示。
引入數(shù)組就不需要在程序中定義大量的變量,大大減少程序中變量的數(shù)量,使程序精煉,而且數(shù)組含義清楚,使用方便,明確地反映了數(shù)據(jù)間的聯(lián)系。許多好的算法都與數(shù)組有關(guān)。熟練地利用數(shù)組,可以大大地提高編程和解題的效率,加強了程序的可讀性。
C++用方括號來表示下標,如用s[1],s[2],s[3] 分別代表s1,s2,s3。
C++用數(shù)組名作函數(shù)參數(shù)
常量和變量可以用作函數(shù)實參,同樣數(shù)組元素也可以作函數(shù)實參,其用法與變量相同。數(shù)組名也可以作實參和形參,傳遞的是數(shù)組的起始地址。
用數(shù)組元素作函數(shù)實參
由于實參可以是表達式,而數(shù)組元素可以是表達式的組成部分,因此數(shù)組元素當(dāng)然可以作為函數(shù)的實參,與用變量作實參一樣,將數(shù)組元素的值傳送給形參變量。
【例】用函數(shù)處理。
今設(shè)一函數(shù)max_value,用來進行比較并返回結(jié)果??删帉懗绦蛉缦拢?br />
#include <iostream>
using namespace std;
int main( )
{
int max_value(int x,int max); //函數(shù)聲明
int i,j,row=0,colum=0,max
int a[3][4]={{5,12,23,56},{19,28,37,46},{-12,-34,6,8}}; //數(shù)組初始化
max=a[0][0];
for (i=0;i<=2;i++)
for (j=0;j<=3;j++)
{
max=max_value(a[i][j],max); //調(diào)用max_value函數(shù)
if(max==a[i][j])//如果函數(shù)返回的是a[i][j]的值
{
row=i; //記下該元素行號i
colum=j; //記下該元素列號j
}
}
cout<<"max="<<max<<",row="<<row<<",colum="<<colum<<endl;
}
int max_value(int x,int max)//定義max_value函數(shù)
{
if(x>max) return x;//如果x>max,函數(shù)返回值為x
else return max;//如果x≤max,函數(shù)返回值為max
}
用數(shù)組名作函數(shù)參數(shù)
可以用數(shù)組名作函數(shù)參數(shù),此時實參與形參都用數(shù)組名(也可以用指針變量,見第6章)。
【例】用選擇法對數(shù)組中10個整數(shù)按由小到大排序。
所謂選擇法就是先將10個數(shù)中最小的數(shù)與a[0]對換,再將a[1]到a[9]中最小的數(shù)與a[1]對換……每比較一輪,找出一個未經(jīng)排序的數(shù)中最小的一個。共比較9輪。根據(jù)此思路編寫程序如下:
#include <iostream>
using namespace std;
int main( )
{
void select_sort(int array[],int n); //函數(shù)聲明
int a[10],i;
cout<<"enter the originl array:"<<endl;
for(i=0;i<10;i++) //輸入10個數(shù)
cin>>a[i];
cout<<endl;
select_sort(a,10);//函數(shù)調(diào)用,數(shù)組名作實參
cout<<"the sorted array:"<<endl;
for(i=0;i<10;i++) //輸出10個已排好序的數(shù)
cout<<a[i]<<" ";
cout<<endl;
return 0;
}
void select_sort(int array[],int n) //形參array是數(shù)組名
{
int i,j,k,t;
for(i=0;i<n-1;i++)
{
k=i;
for(j=i+1;j<n;j++)
if(array[j]<array[k]) k=j;
t=array[k];array[k]=array[i];array[i]=t;
}
}
運行情況如下:
enter the originl array: 6 9 -2 56 87 11 -54 3 0 77↙ //輸入10個數(shù) the sorted array: -54 -2 0 3 6 9 11 56 77 87
關(guān)于用數(shù)組名作函數(shù)參數(shù)有兩點要說明:
1) 如果函數(shù)實參是數(shù)組名,形參也應(yīng)為數(shù)組名(或指針變量),形參不能聲明為普通變量(如int array;)。實參數(shù)組與形參數(shù)組類型應(yīng)一致(現(xiàn)都為int型),如不一致,結(jié)果將出錯。
2) 需要特別說明的是: 數(shù)組名代表數(shù)組首元素的地址,并不代表數(shù)組中的全部元素。因此用數(shù)組名作函數(shù)實參時,不是把實參數(shù)組的值傳遞給形參,而只是將實參數(shù)組首元素的地址傳遞給形參。
形參可以是數(shù)組名,也可以是指針變量,它們用來接收實參傳來的地址。如果形參是數(shù)組名,它代表的是形參數(shù)組首元素的地址。在調(diào)用函數(shù)時,將實參數(shù)組首元素的地址傳遞給形參數(shù)組名。這樣,實參數(shù)組和形參數(shù)組就共占同一段內(nèi)存單元。見圖。
在用變量作函數(shù)參數(shù)時,只能將實參變量的值傳給形參變量,在調(diào)用函數(shù)過程中如果改變了形參的值,對實參沒有影響,即實參的值不因形參的值改變而改變。而用數(shù)組名作函數(shù)實參時,改變形參數(shù)組元素的值將同時改變實參數(shù)組元素的值。在程序設(shè)計中往往有意識地利用這一特點改變實參數(shù)組元素的值。
實際上,聲明形參數(shù)組并不意味著真正建立一個包含若干元素的數(shù)組,在調(diào)用函數(shù)時也不對它分配存儲單元,只是用array[]這樣的形式表示array是一維數(shù)組名,以接收實參傳來的地址。因此array[]中方括號內(nèi)的數(shù)值并無實際作用,編譯系統(tǒng)對一維數(shù)組方括號內(nèi)的內(nèi)容不予處理。形參一維數(shù)組的聲明中可以寫元素個數(shù),也可以不寫。
函數(shù)首部的下面幾種寫法都合法,作用相同:
void select_sort(int array[10],int n) //指定元素個數(shù)與實參數(shù)組相同 void select_sort(int array[],int n) //不指定元素個數(shù) void select_sort(int array[5],int n) //指定元素個數(shù)與實參數(shù)組不同
C++實際上只把形參數(shù)組名作為一個指針變量來處理,用來接收從實參傳過來的地址。前面提到的一些現(xiàn)象都是由此而產(chǎn)生的。
用多維數(shù)組名作函數(shù)參數(shù)
如果用二維數(shù)組名作為實參和形參,在對形參數(shù)組聲明時,必須指定第二維(即列)的大小,且應(yīng)與實參的第二維的大小相同。第一維的大小可以指定,也可以不指定。如:
int array[3][10]; //形參數(shù)組的兩個維都指定
或
int array[][10]; //第一維大小省略
二者都合法而且等價。但是不能把第二維的大小省略。下面的形參數(shù)組寫法不合法:
int array[][]; //不能確定數(shù)組的每一行有多少列元素 int array[3][]; //不指定列數(shù)就無法確定數(shù)組的結(jié)構(gòu)
在第二維大小相同的前提下,形參數(shù)組的第一維可以與實參數(shù)組不同。例如,實參數(shù)組定義為:
int score[5][10];
而形參數(shù)組可以聲明為:
int array[3][10]; //列數(shù)與實參數(shù)組相同,行數(shù)不同 int array[8][10];
這時形參二維數(shù)組與實參二維數(shù)組都是由相同類型和大小的一維數(shù)組組成的,實參數(shù)組名score代表其首元素(即第一行)的起始地址,系統(tǒng)不檢查第一維的大小。
如果是三維或更多維的數(shù)組,處理方法是類似的。
【例】有一個3×4的矩陣,求矩陣中所有元素中的最大值。要求用函數(shù)處理。
解此題的程序如下:
#include <iostream>
using namespace std;
int main( )
{
int max_value(int array[][4]);
int a[3][4]={{11,32,45,67},{22,44,66,88},{15,72,43,37}};
cout<<"max value is "<<max_value(a)<<endl;
return 0;
}
int max_value(int array[][4])
{
int i,j,max;
max=array[0][0];
for( i=0;i<3;i++)
for(j=0;j<4;j++)
if(array[i][j]>max) max=array[i][j];
return max;
}
運行結(jié)果如下:
max value is 88
讀者可以將max_value函數(shù)的首部改為以下幾種情況,觀察編譯情況:
int max_value(int array[][]) int max_value(int array[3][]) int max_value(int array[3][4]) int max_value(int array[10][10]) int max_value(int array[12])
上一篇:講解C++的do while循環(huán)和循環(huán)語句的嵌套使用方法
欄 目:C語言
下一篇:C++字符數(shù)組的輸入輸出和字符串結(jié)束標志使用講解
本文標題:詳解C++編程中用數(shù)組名作函數(shù)參數(shù)的方法
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/2752.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10求子數(shù)組最大和的解決方法詳解
- 01-10深入二叉樹兩個結(jié)點的最低共同父結(jié)點的詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計- 解析最少換車次數(shù)的問題詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-用棧實現(xiàn)表達式求值的方法詳解
- 01-10HDOJ 1443 約瑟夫環(huán)的最新應(yīng)用分析詳解
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10如何查看進程實際的內(nèi)存占用情況詳解
- 01-10深入Main函數(shù)中的參數(shù)argc,argv的使用詳解


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結(jié)
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 04-02jquery與jsp,用jquery
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什


