中文字幕理论片,69视频免费在线观看,亚洲成人app,国产1级毛片,刘涛最大尺度戏视频,欧美亚洲美女视频,2021韩国美女仙女屋vip视频

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
C語(yǔ)言數(shù)組名作函數(shù)參數(shù)

數(shù)組名可以作函數(shù)的實(shí)參和形參。如:
  1. main(){
  2. int array[10];
  3. /* …… */
  4. /* …… */
  5. f(array,10);
  6. /* …… */
  7. /* …… */
  8. }
  9. f(int arr[],int n);
  10. {
  11. /* …… */
  12. /* …… */
  13. }
array為實(shí)參數(shù)組名,arr為形參數(shù)組名。在學(xué)習(xí)指針變量之后就更容易理解這個(gè)問(wèn)題了。數(shù)組名就是數(shù)組的首地址,實(shí)參向形參傳送數(shù)組名實(shí)際上就是傳送數(shù)組的地址,形參得到該地址后也指向同一數(shù)組。這就好象同一件物品有兩個(gè)彼此不同的名稱一樣。


同樣,指針變量的值也是地址,數(shù)組指針變量的值即為數(shù)組的首地址,當(dāng)然也可作為函數(shù)的參數(shù)使用。

【例10-15】
  1. float aver(float *pa);
  2. main(){
  3. float sco[5],av,*sp;
  4. int i;
  5. sp=sco;
  6. printf("\ninput 5 scores:\n");
  7. for(i=0;i<5;i++) scanf("%f",&sco[i]);
  8. av=aver(sp);
  9. printf("average score is %5.2f",av);
  10. }
  11. float aver(float *pa){
  12. int i;
  13. float av,s=0;
  14. for(i=0;i<5;i++) s=s+*pa++;
  15. av=s/5;
  16. return av;
  17. }

【例10-16】將數(shù)組a中的n個(gè)整數(shù)按相反順序存放。
算法為:將a[0]與a[n-1]對(duì)換,再a[1]與a[n-2] 對(duì)換……,直到將a[(n-1/2)]與a[n-int((n-1)/2)]對(duì)換。今用循環(huán)處理此問(wèn)題,設(shè)兩個(gè)“位置指示變量”i和j,i的初值為0,j的初值為n-1。將a[i]與a[j]交換,然后使i的值加1,j的值減1,再將a[i]與a[j]交換,直到i=(n-1)/2為止,如圖所示。


程序如下:
  1. void inv(int x[],int n) /*形參x是數(shù)組名*/{
  2. int temp,i,j,m=(n-1)/2;
  3. for(i=0;i<=m;i++){
  4. j=n-1-i;
  5. temp=x[i];x[i]=x[j];x[j]=temp;
  6. }
  7. return;
  8. }
  9. main(){
  10. int i,a[10]={3,7,9,11,0,6,7,5,4,2};
  11. printf("The original array:\n");
  12. for(i=0;i<10;i++)
  13. printf("%d,",a[i]);
  14. printf("\n");
  15. inv(a,10);
  16. printf("The array has benn inverted:\n");
  17. for(i=0;i<10;i++)
  18. printf("%d,",a[i]);
  19. printf("\n");
  20. }
對(duì)此程序可以作一些改動(dòng)。將函數(shù)inv中的形參x改成指針變量。

【例10-17】將函數(shù)inv中的形參x改成指針變量。程序如下:
  1. void inv(int *x,int n){ /*形參x為指針變量*/
  2. int *p,temp,*i,*j,m=(n-1)/2;
  3. i=x;j=x+n-1;p=x+m;
  4. for(;i<=p;i++,j--){
  5. temp=*i;
  6. *i=*j;
  7. *j=temp;
  8. }
  9. return;
  10. }
  11. main(){
  12. int i,a[10]={3,7,9,11,0,6,7,5,4,2};
  13. printf("The original array:\n");
  14. for(i=0;i<10;i++)
  15. printf("%d,",a[i]);
  16. printf("\n");
  17. inv(a,10);
  18. printf("The array has benn inverted:\n");
  19. for(i=0;i<10;i++)
  20. printf("%d,",a[i]);
  21. printf("\n");
  22. }
運(yùn)行情況與前一程序相同。

【例10-18】從0個(gè)數(shù)中找出其中最大值和最小值。

調(diào)用一個(gè)函數(shù)只能得到一個(gè)返回值,今用全局變量在函數(shù)之間“傳遞”數(shù)據(jù)。程序如下:
  1. int max,min; /*全局變量*/
  2. void max_min_value(int array[],int n){
  3. int *p,*array_end;
  4. array_end=array+n;
  5. max=min=*array;
  6. for(p=array+1;p<array_end;p++)
  7. if(*p>max) max=*p;
  8. else if (*p<min)min=*p;
  9. return;
  10. }
  11. main(){
  12. int i,number[10];
  13. printf("enter 10 integer umbers:\n");
  14. for(i=0;i<10;i++)
  15. scanf("%d",&number[i]);
  16. max_min_value(number,10);
  17. printf("\nmax=%d,min=%d\n",max,min);
  18. }
說(shuō)明:
1) 在函數(shù)max_min_value中求出的最大值和最小值放在max和min中。由于它們是全局,因此在主函數(shù)中可以直接使用。

2) 函數(shù)max_min_value中的語(yǔ)句:
    max=min=*array;
array是數(shù)組名,它接收從實(shí)參傳來(lái)的數(shù)組numuber的首地址。

*array相當(dāng)于*(&array[0])。上述語(yǔ)句與 max=min=array[0];等價(jià)。

3) 在執(zhí)行for循環(huán)時(shí),p的初值為array+1,也就是使p指向array[1]。以后每次執(zhí)行p++,使p指向下一個(gè)元素。每次將*p和max與min比較。將大者放入max,小者放min。


4) 函數(shù)max_min_value的形參array可以改為指針變量類(lèi)型。實(shí)參也可以不用數(shù)組名,而用指針變量傳遞地址。

【例10-19】程序可改為:
  1. int max,min; /*全局變量*/
  2. void max_min_value(int *array,int n){
  3. int *p,*array_end;
  4. array_end=array+n;
  5. max=min=*array;
  6. for(p=array+1;p<array_end;p++)
  7. if(*p>max) max=*p;
  8. else if (*p<min)min=*p;
  9. return;
  10. }
  11. main(){
  12. int i,number[10],*p;
  13. p=number; /*使p指向number數(shù)組*/
  14. printf("enter 10 integer umbers:\n");
  15. for(i=0;i<10;i++,p++)
  16. scanf("%d",p);
  17. p=number;
  18. max_min_value(p,10);
  19. printf("\nmax=%d,min=%d\n",max,min);
  20. }

歸納起來(lái),如果有一個(gè)實(shí)參數(shù)組,想在函數(shù)中改變此數(shù)組的元素的值,實(shí)參與形參的對(duì)應(yīng)關(guān)系有以下4種:

1) 形參和實(shí)參都是數(shù)組名。
  1. main(){
  2. int a[10];
  3. /* …… */
  4. f(a,10)
  5. /* …… */
  6. f(int x[],int n){
  7. /* …… */
  8. }
  9. }
a 和 x 指的是同一組數(shù)組。

2) 實(shí)用數(shù)組,形參用指針變量。
  1. main(){
  2. int a[10];
  3. /* …… */
  4. f(a,10)
  5. /* …… */
  6. f(int *x,int n){
  7. /* …… */
  8. }
  9. }

3) 實(shí)參、型參都用指針變量。

4) 實(shí)參為指針變量,型參為數(shù)組名。

【例10-20】用實(shí)參指針變量改寫(xiě)將n個(gè)整數(shù)按相反順序存放。
  1. void inv(int *x,int n){
  2. int *p,m,temp,*i,*j;
  3. m=(n-1)/2;
  4. i=x;j=x+n-1;p=x+m;
  5. for(;i<=p;i++,j--){
  6. temp=*i;
  7. *i=*j;
  8. *j=temp;
  9. }
  10. return;
  11. }
  12. main(){
  13. int i,arr[10]={3,7,9,11,0,6,7,5,4,2},*p;
  14. p=arr;
  15. printf("The original array:\n");
  16. for(i=0;i<10;i++,p++)
  17. printf("%d,",*p);
  18. printf("\n");
  19. p=arr;
  20. inv(p,10);
  21. printf("The array has benn inverted:\n");
  22. for(p=arr;p<arr+10;p++)
  23. printf("%d,",*p);
  24. printf("\n");
  25. }
注意:main函數(shù)中的指針變量p是有確定值的。即如果用指針變作實(shí)參,必須現(xiàn)使指針變量有確定值,指向一個(gè)已定義的數(shù)組。

【例10.21】用選擇法對(duì)10個(gè)整數(shù)排序。
  1. main(){
  2. int *p,i,a[10]={3,7,9,11,0,6,7,5,4,2};
  3. printf("The original array:\n");
  4. for(i=0;i<10;i++)
  5. printf("%d,",a[i]);
  6. printf("\n");
  7. p=a;
  8. sort(p,10);
  9. for(p=a,i=0;i<10;i++){
  10. printf("%d ",*p);
  11. p++;
  12. }
  13. printf("\n");
  14. }
  15. sort(int x[],int n){
  16. int i,j,k,t;
  17. for(i=0;i<n-1;i++){
  18. k=i;
  19. for(j=i+1;j<n;j++)
  20. if(x[j]>x[k])k=j;
  21. if(k!=i){
  22. t=x[i];
  23. x[i]=x[k];
  24. x[k]=t;
  25. }
  26. }
  27. }
說(shuō)明:函數(shù)sort用數(shù)組名作為形參,也可改為用指針變量,這時(shí)函數(shù)的首部可以改為:
    sort(int *x,int n)
其他可一律不改。

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
C語(yǔ)言關(guān)于指針的總結(jié)
C語(yǔ)言學(xué)習(xí)——指針精華(3)工程項(xiàng)目復(fù)習(xí)
C/C++筆試題-主要考察C/C++語(yǔ)言基礎(chǔ)概念、算法及編程,附參考答案
【轉(zhuǎn)載】C/C++的面試題
對(duì)于C語(yǔ)言中指針和數(shù)組的認(rèn)識(shí)和看法
已學(xué)怎么擅用指針?
更多類(lèi)似文章 >>
生活服務(wù)
熱點(diǎn)新聞
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服