這篇文章主要介紹了c++將數組名作為函數參數對數組元素進行相應的運算,需要的朋友可以參考下
用數組名做函數參數與用數組元素作實參有幾點不同:
(1)用數組元素作實參時,只要數群組類型和函數的形參變數的類型一致,那麼作為下標變數的數組元素的類型也和函數形參變數的類型是一致的。因此,並不要求函數的形參也是下標變數。換句話說,對數組元素的處理是按普通變數對待的。用數組名作函數參數時,則要求形參和相應的實參都必須是類型相同的數組,都必須有明確的數組說明。當形參和實參兩者類型不一致時,將會發生錯誤。
(2)用普通變數或下標變數作函數參數時,形參變數和實參變數都是由編譯系統分配的兩個不同的記憶體單元。在函數調用時進行的值傳遞是把實參變數的值賦予形參變數。在用數組名做函數參數時,不是進行值的傳遞,即不是把實參數組的每一個元素的值都賦予形參數組的各個元素。因為實際上形參數組並不存在,編譯系統不為形參數組分配記憶體。因為數組名就是數組的首地址。因此用數組名做函數參數時所進行的傳遞實際上是地址的傳遞,也就是把實參數組的首地址賦予形參數組名。形參數組名取得該首地址後,也就等於有了具體的地址。實際上是形參數組和實參數組為同一數組,共同使用一段記憶體空間。
代碼如下:
//例:一維數組score,存放10個學生的成績,求平均值。
#include
#include
#include
#include
float average(float array[10])
{ int i;
float aver,sum=array[0];
for(i=1; i<10; i++)
sum=sum+array[i];
aver=sum/10;
return aver;
}
void main()
{ float score[10],aver;
int i;
printf("input 10 score:\n");
for(i=0; i<10; i++)
scanf("%f",&score[i]);
printf("\n");
aver=average(score);
printf("average score is %5.2f\n",aver);
}
說明:
(1)用數組名作函數參數,應該在主調函數和被調函數中分別定義數組。
(2)實參數組與形參數群組類型應一致,如不一致,結果將出錯。
(3)實際上,指定被調函數中形參數組的大小是不起任何作用的,因為C編譯器對形參數組大小不做檢查,只是將形參數組的首地址傳給形參數組。
(4)形參數組也可以不指定大小,定義數組時在數組名後跟一個空的中括弧,為了在被調函數中處理數組元素的需要,可以另設一個參數,傳遞數組元素的個數。
代碼如下:
#include
#include
#include
#include
float average(float array[],int n)
{ int i;
float aver,sum=array[0];
for(i=1; i
sum=sum+array[i];
aver=sum/n;
return aver;
}
void main()
{ float score1[5]= {98.5,97,91.5,60,55};
float score2[10]= {67.5,89.5,99,69.5,77,89.5,76.5,54,60,99.5};
printf("the average of class A is %6.2f\n",average(score1,5));
printf("the average of class B is %6.2f\n",average(score2,10));
}
注:更多精彩文章請關注幫客之家編程教程欄目。