你好!
“只有客戶發(fā)展了,才有我們的生存與發(fā)展!”這是創(chuàng)新互聯(lián)建站的服務(wù)宗旨!把網(wǎng)站當(dāng)作互聯(lián)網(wǎng)產(chǎn)品,產(chǎn)品思維更注重全局思維、需求分析和迭代思維,在網(wǎng)站建設(shè)中就是為了建設(shè)一個不僅審美在線,而且實用性極高的網(wǎng)站。創(chuàng)新互聯(lián)對網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)站制作、網(wǎng)站開發(fā)、網(wǎng)頁設(shè)計、網(wǎng)站優(yōu)化、網(wǎng)絡(luò)推廣、探索永無止境。
將函數(shù)采用指針的形式返回平均值
注意看后面的注釋
#includestdio.h
int?main()
{
float?*student_aver(float?array[3][3]);???//?改成指針的形式輸出?
float?score[3][3];
float?*a;
int?i,j;
printf("請輸入學(xué)生各科的成績:");
for(i=0;i3;i++)
for(j=0;j3;j++)
scanf("%f",score[i][j]);
printf("每個學(xué)生的平均成績分別為:");
a=student_aver(score);????????????????//?指針?a?接收函數(shù)的返回值?
for(i=0;i3;i++)??????????????????????//?打印出平均值?
printf("%.2f?",a[i]);
return?0;
}
float?*student_aver(float?array[3][3])????//?改成指針的形式輸出
{
int?i,j;
float?sum,a[3];
for(i=0;i3;i++)
{
sum=0;
for(j=0;j3;j++)
sum=sum+array[i][j];
a[i]=sum/3;
???}
return?a;?????????????????????????????//?輸出數(shù)組?a?
}
不能直接返回一個數(shù)組,但是可以用其他方式實現(xiàn)類似功能。
方法1:利用全局變量
分析:全局變量作為C語言的一個知識點,雖然我們都了解它的特點,但在實際教學(xué)過程中應(yīng)用得并不是很多。由于全局變量的作用域是從定義變量開始直到程序結(jié)束,而對于編寫有多個返回值的C語言函數(shù),我們可以考慮把要返回的多個值定義成全局變量。當(dāng)函數(shù)被調(diào)用時,全局變量被更改,我們再把更改后的全局變量值應(yīng)用于主調(diào)函數(shù)中。函數(shù)被調(diào)用后被更改后的全局變量值即為函數(shù)的數(shù)個返回值。下面以一個實例演示該方法的應(yīng)用。
實例1:編寫函數(shù)求3個數(shù)中的最大值與最小值。
方法:把最大值、最小值分別定義成2個全局變量max、min,在用戶自定義函數(shù)中把求出來的最大值與最小值分別賦給全局變量max、min。函數(shù)調(diào)用完畢后全局變量的max、min值即保存了函數(shù)要求返回的值。程序參考代碼如下:
#include "stdio.h"
#include "conio.h"
int max,min;/*定義兩個全局變量用于保存函數(shù)返回值*/
void max_min(int a,int b,int c) /*定義求最大最小值的函數(shù)*/
{max=min=a; /*初始化最大最小值*/
if(max if(max if(minb)min=b;
if(minc)min=c;
}
main()
{int x,y,z;
printf(" 請輸入3個整數(shù):\n");
scanf("%d,%d,%d",x,y,z);
max_min(x,y,z) ;/*調(diào)用求最大值與最小值的函數(shù)*/
printf("三個數(shù)中的最大值為:%d;最小值為:%d",max,min);/*輸出最大值與最小值*/
getch();
}
調(diào)試結(jié)果如下:
請輸入3個整數(shù):
5,-6,2
三個數(shù)中的最大值為:5;最小值為:-6
注意:該方法雖然可以實現(xiàn)有多個返回值的函數(shù),但由于全局變量不能保證值的正確性(因為其作用域是全局,所以程序范圍內(nèi)都可以修改它的值,如果出現(xiàn)錯誤將非常難以發(fā)現(xiàn)),并且全局變量增加了程序間模塊的耦合,所以該方法要慎用。
方法2:傳遞數(shù)組指針
分析:在教學(xué)過程中,我們知道C語言函數(shù)參數(shù)的傳遞方式有值傳遞與地址傳遞。當(dāng)進(jìn)行值傳遞時,主調(diào)函數(shù)把實參的值復(fù)制給形參,形參獲得從主調(diào)函數(shù)傳遞過來的值運行函數(shù)。在值傳遞過程中被調(diào)函數(shù)參數(shù)值的更改不能導(dǎo)致實參值的更改。而如果是地址傳遞,由于傳遞過程中從實參傳遞過來的是地址,所以被調(diào)函數(shù)中形參值的更改會直接導(dǎo)致實參值的更改。因此,我們可以考慮把多個返回值作為數(shù)組元素定義成一個數(shù)組的形式,并使該數(shù)組的地址作為函數(shù)的形式參數(shù),以傳址方式傳遞數(shù)組參數(shù)。函數(shù)被調(diào)用后,形參數(shù)組元素改變導(dǎo)致實參改變,我們再從改變后的實參數(shù)組元素中獲得函數(shù)的多個返回值。以下實例演示該方法的應(yīng)用。
實例2:編寫函數(shù)求一維整形數(shù)組的最大值與最小值,并把最大值與最小值返回給主調(diào)函數(shù)。
方法:以指針方式傳遞該一維數(shù)組的地址,然后把數(shù)組的最大值與數(shù)組的第一個元素交換,把數(shù)組的最小值與最后一個元素交換。函數(shù)被調(diào)用完畢后,實參數(shù)組中的第一元素為數(shù)組的最大值,實參數(shù)組中最后一個元素為數(shù)組的最小值,從而實現(xiàn)返回數(shù)組的最大值與最小值的功能。程序參考代碼如下:
#include "stdio.h"
#include "conio.h"
void max_min(int *ptr,int n) /*定義求數(shù)組最大值最小值的函數(shù),傳遞數(shù)組指針*/
{int i,j,k;/*j保存最大值所在位置,k保存最小值所在位置*/
int *temp;/*用于交換位置*/
*temp=*ptr;
for(i=0;i{
if(*ptr*(ptr+i))/*最大值與第一個元素進(jìn)行交換*/
{
k=i;
*temp=*ptr;
*ptr=*(ptr+k);
*(ptr+k)=*temp ;
}
if(*(ptr+n-1)*(ptr+i))/*最小值與最后一個元素進(jìn)行交換*/
{
j=i;
*temp =*(ptr+n-1);
*(ptr+n-1)=*(ptr+j);
*(ptr+j)= *temp ;}
}
}
/*調(diào)用最大最小值函數(shù)*/
main()
{
int A[6],i;
for(i=0;i6;i++)
scanf("%d",A[i]);
max_min(A,6);
printf("max=%d, min=%d\n \n",A[0],A[5]);
getch();
}
調(diào)試結(jié)果如下:
請輸入6個整形數(shù),以空格隔開:
5 8 9 32 -6 4
max=32,min=-6
注意:該方法適用于多個返回值的數(shù)據(jù)類型一致的情況。當(dāng)返回值數(shù)據(jù)類型不一致時,不適用該方法
你的程序:
main()
{
int
b[3];
b=pop();
}
int
*
pop()
{
int
a[3],i;//定義的局部變量a[3]在調(diào)用完之后自動釋放其空間
for(i=0;i3;i++)
a[i]=i;
return
a;//返回的是指向數(shù)組a[3]的地址而不是數(shù)組a[3]本身
}
注:既然上面說到調(diào)用的方法返回的是指向數(shù)組a[3]的地址,所以主函數(shù)中b接收的應(yīng)該是指向數(shù)組a[3]的地址,而數(shù)組a[3]在方法調(diào)用完后又被釋放了,所以b接收不到數(shù)組a[3],故出錯。
正確的程序:
#includestdio.h
main()
{
int
b[3];
pop(b,3);
}
void
pop(int
a[],int
n)//該方法傳入兩個參數(shù),第一個是傳入指向數(shù)組的地址,第二個參數(shù)是傳入數(shù)組的長度,不需寫返回語句return,只需通過指向數(shù)組的地址的傳入就可以直接將數(shù)組b[]的值改變
{
int
i;
for(i=0;in;i++)
a[i]=i;
}
C/C++不能直接返回一個數(shù)組。這是由于在C/C++中,數(shù)組不是一種類型,因此不能被直接返回。 在C/C++中,一般有兩種方法來返回一個數(shù)組。 第一種方法: 返回一個指向數(shù)組的指針,例如char (*retArray)[10]聲明了一個函數(shù)retArray,該函數(shù)可以返回指向具有10個char元素的數(shù)組例子如下:#include#includeint (*retArray())[10]{int (*a)[10];int i=0;/*動態(tài)開辟空間*/ a=calloc(10,sizeof(int));/*賦值*/for(i=0;i10;i++){(*a)[i]=i;}return a;}int main(){int (*b)[10]; /*函數(shù)返回指向數(shù)組的指針*/ b=retArray(); /*打印第一個元素*/ printf("%d/n",(*b)[0]); /*釋放空間*/free(b);return 0;}第二種方法: 如果你不喜歡用指針的形式返回數(shù)組,那么可以采用返回一個結(jié)構(gòu)的形式。這種形式相對較安全,可以避免忘記釋放指針而造成內(nèi)存泄露,也可以避免訪問懸掛指針造成的錯誤。但缺點是由于結(jié)構(gòu)是先拷貝再返回,因此如果結(jié)構(gòu)較大時,會影響效率和占用較大內(nèi)存。 例子如下:#includestruct tag{int a[10];}x,y;struct tag retArray(){int i=0;for(i=0;i10;i++) x.a[i]=i;return x;}int main(){struct tag y=retArray(); printf("%d/n",y.a[3]);return 0;}注意:(1)在返回指針時要切記要避免內(nèi)存泄露和訪問懸掛指針。 (2)很多人認(rèn)為指針和數(shù)組等價的,這是錯誤的。int (*a)[10]和int b[10]兩者是不能直接用a=b來賦值的。在數(shù)組和指針作為函數(shù)參數(shù)傳遞時,二者可以認(rèn)為等價,這是因為數(shù)組會被轉(zhuǎn)化為指針來傳遞。 (3)返回多維數(shù)組方法類似。
你想返回一個數(shù)組,因為你在一個函數(shù)內(nèi)創(chuàng)建了數(shù)組,屬于局部變量,所以他在stack部分,而stack部分是用后類似于銷毀的,你返回的地址類似于一塊垃圾的地址,所以編譯警告。你要想返回函數(shù)內(nèi)創(chuàng)建的數(shù)組地址的話需要
//inside?a?function
{
//?n?is?the?size?of?the?array;
int*?array?=?(int?*)malloc(sizeof(int)*n);
/*
do?something?with?array
*/
return?array;
}
這樣這個數(shù)組建立在heap堆上,調(diào)用完函數(shù)還在,而你返回了那個堆上數(shù)組的首地址,這樣就沒問題了。
用完free(array);
樓上用static不推薦,用static的話會在整個程序的run time運行時都占用空間。而是用malloc,動態(tài)申請釋放更合理。