最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
返回?cái)?shù)組的函數(shù)c語(yǔ)言 c語(yǔ)言中返回?cái)?shù)組

在C語(yǔ)言中如何使函數(shù)返回?cái)?shù)組

C/C++不能直接返回一個(gè)數(shù)組。這是由于在C/C++中,數(shù)組不是一種類型,因此不能被直接返回。 在C/C++中,一般有兩種方法來(lái)返回一個(gè)數(shù)組。 第一種方法: 返回一個(gè)指向數(shù)組的指針,例如char (*retArray)[10]聲明了一個(gè)函數(shù)retArray,該函數(shù)可以返回指向具有10個(gè)char元素的數(shù)組例子如下:#include#includeint (*retArray())[10]{int (*a)[10];int i=0;/*動(dòng)態(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(); /*打印第一個(gè)元素*/ printf("%d/n",(*b)[0]); /*釋放空間*/free(b);return 0;}第二種方法: 如果你不喜歡用指針的形式返回?cái)?shù)組,那么可以采用返回一個(gè)結(jié)構(gòu)的形式。這種形式相對(duì)較安全,可以避免忘記釋放指針而造成內(nèi)存泄露,也可以避免訪問(wèn)懸掛指針造成的錯(cuò)誤。但缺點(diǎn)是由于結(jié)構(gòu)是先拷貝再返回,因此如果結(jié)構(gòu)較大時(shí),會(huì)影響效率和占用較大內(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)在返回指針時(shí)要切記要避免內(nèi)存泄露和訪問(wèn)懸掛指針。 (2)很多人認(rèn)為指針和數(shù)組等價(jià)的,這是錯(cuò)誤的。int (*a)[10]和int b[10]兩者是不能直接用a=b來(lái)賦值的。在數(shù)組和指針作為函數(shù)參數(shù)傳遞時(shí),二者可以認(rèn)為等價(jià),這是因?yàn)閿?shù)組會(huì)被轉(zhuǎn)化為指針來(lái)傳遞。 (3)返回多維數(shù)組方法類似。

創(chuàng)新互聯(lián)公司專注于企業(yè)網(wǎng)絡(luò)營(yíng)銷推廣、網(wǎng)站重做改版、寧強(qiáng)網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)、商城網(wǎng)站開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為寧強(qiáng)等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

C語(yǔ)言函數(shù)中返回?cái)?shù)組

你的程序:

main()

{

int

b[3];

b=pop();

}

int

*

pop()

{

int

a[3],i;//定義的局部變量a[3]在調(diào)用完之后自動(dòng)釋放其空間

for(i=0;i3;i++)

a[i]=i;

return

a;//返回的是指向數(shù)組a[3]的地址而不是數(shù)組a[3]本身

}

注:既然上面說(shuō)到調(diào)用的方法返回的是指向數(shù)組a[3]的地址,所以主函數(shù)中b接收的應(yīng)該是指向數(shù)組a[3]的地址,而數(shù)組a[3]在方法調(diào)用完后又被釋放了,所以b接收不到數(shù)組a[3],故出錯(cuò)。

正確的程序:

#includestdio.h

main()

{

int

b[3];

pop(b,3);

}

void

pop(int

a[],int

n)//該方法傳入兩個(gè)參數(shù),第一個(gè)是傳入指向數(shù)組的地址,第二個(gè)參數(shù)是傳入數(shù)組的長(zhǎng)度,不需寫返回語(yǔ)句return,只需通過(guò)指向數(shù)組的地址的傳入就可以直接將數(shù)組b[]的值改變

{

int

i;

for(i=0;in;i++)

a[i]=i;

}

c語(yǔ)言中函數(shù)能返回一個(gè)數(shù)組嗎

不能直接返回一個(gè)數(shù)組,但是可以用其他方式實(shí)現(xiàn)類似功能。

方法1:利用全局變量

分析:全局變量作為C語(yǔ)言的一個(gè)知識(shí)點(diǎn),雖然我們都了解它的特點(diǎn),但在實(shí)際教學(xué)過(guò)程中應(yīng)用得并不是很多。由于全局變量的作用域是從定義變量開始直到程序結(jié)束,而對(duì)于編寫有多個(gè)返回值的C語(yǔ)言函數(shù),我們可以考慮把要返回的多個(gè)值定義成全局變量。當(dāng)函數(shù)被調(diào)用時(shí),全局變量被更改,我們?cè)侔迅暮蟮娜肿兞恐祽?yīng)用于主調(diào)函數(shù)中。函數(shù)被調(diào)用后被更改后的全局變量值即為函數(shù)的數(shù)個(gè)返回值。下面以一個(gè)實(shí)例演示該方法的應(yīng)用。

實(shí)例1:編寫函數(shù)求3個(gè)數(shù)中的最大值與最小值。

方法:把最大值、最小值分別定義成2個(gè)全局變量max、min,在用戶自定義函數(shù)中把求出來(lái)的最大值與最小值分別賦給全局變量max、min。函數(shù)調(diào)用完畢后全局變量的max、min值即保存了函數(shù)要求返回的值。程序參考代碼如下:

#include "stdio.h"

#include "conio.h"

int max,min;/*定義兩個(gè)全局變量用于保存函數(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(" 請(qǐng)輸入3個(gè)整數(shù):\n");

scanf("%d,%d,%d",x,y,z);

max_min(x,y,z) ;/*調(diào)用求最大值與最小值的函數(shù)*/

printf("三個(gè)數(shù)中的最大值為:%d;最小值為:%d",max,min);/*輸出最大值與最小值*/

getch();

}

調(diào)試結(jié)果如下:

請(qǐng)輸入3個(gè)整數(shù):

5,-6,2

三個(gè)數(shù)中的最大值為:5;最小值為:-6

注意:該方法雖然可以實(shí)現(xiàn)有多個(gè)返回值的函數(shù),但由于全局變量不能保證值的正確性(因?yàn)槠渥饔糜蚴侨?,所以程序范圍?nèi)都可以修改它的值,如果出現(xiàn)錯(cuò)誤將非常難以發(fā)現(xiàn)),并且全局變量增加了程序間模塊的耦合,所以該方法要慎用。

 方法2:傳遞數(shù)組指針

分析:在教學(xué)過(guò)程中,我們知道C語(yǔ)言函數(shù)參數(shù)的傳遞方式有值傳遞與地址傳遞。當(dāng)進(jìn)行值傳遞時(shí),主調(diào)函數(shù)把實(shí)參的值復(fù)制給形參,形參獲得從主調(diào)函數(shù)傳遞過(guò)來(lái)的值運(yùn)行函數(shù)。在值傳遞過(guò)程中被調(diào)函數(shù)參數(shù)值的更改不能導(dǎo)致實(shí)參值的更改。而如果是地址傳遞,由于傳遞過(guò)程中從實(shí)參傳遞過(guò)來(lái)的是地址,所以被調(diào)函數(shù)中形參值的更改會(huì)直接導(dǎo)致實(shí)參值的更改。因此,我們可以考慮把多個(gè)返回值作為數(shù)組元素定義成一個(gè)數(shù)組的形式,并使該數(shù)組的地址作為函數(shù)的形式參數(shù),以傳址方式傳遞數(shù)組參數(shù)。函數(shù)被調(diào)用后,形參數(shù)組元素改變導(dǎo)致實(shí)參改變,我們?cè)購(gòu)母淖兒蟮膶?shí)參數(shù)組元素中獲得函數(shù)的多個(gè)返回值。以下實(shí)例演示該方法的應(yīng)用。

實(shí)例2:編寫函數(shù)求一維整形數(shù)組的最大值與最小值,并把最大值與最小值返回給主調(diào)函數(shù)。

方法:以指針?lè)绞絺鬟f該一維數(shù)組的地址,然后把數(shù)組的最大值與數(shù)組的第一個(gè)元素交換,把數(shù)組的最小值與最后一個(gè)元素交換。函數(shù)被調(diào)用完畢后,實(shí)參數(shù)組中的第一元素為數(shù)組的最大值,實(shí)參數(shù)組中最后一個(gè)元素為數(shù)組的最小值,從而實(shí)現(xiàn)返回?cái)?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))/*最大值與第一個(gè)元素進(jìn)行交換*/

{

k=i;

*temp=*ptr;

*ptr=*(ptr+k);

*(ptr+k)=*temp ;

}

if(*(ptr+n-1)*(ptr+i))/*最小值與最后一個(gè)元素進(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é)果如下:

請(qǐng)輸入6個(gè)整形數(shù),以空格隔開:

5 8 9 32 -6 4

max=32,min=-6

注意:該方法適用于多個(gè)返回值的數(shù)據(jù)類型一致的情況。當(dāng)返回值數(shù)據(jù)類型不一致時(shí),不適用該方法

c語(yǔ)言函數(shù)返回?cái)?shù)組

你好!

將函數(shù)采用指針的形式返回平均值

注意看后面的注釋

#includestdio.h

int?main()

{

float?*student_aver(float?array[3][3]);???//?改成指針的形式輸出?

float?score[3][3];

float?*a;

int?i,j;

printf("請(qǐng)輸入學(xué)生各科的成績(jī):");

for(i=0;i3;i++)

for(j=0;j3;j++)

scanf("%f",score[i][j]);

printf("每個(gè)學(xué)生的平均成績(jī)分別為:");

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?

}


新聞名稱:返回?cái)?shù)組的函數(shù)c語(yǔ)言 c語(yǔ)言中返回?cái)?shù)組
鏈接URL:http://fisionsoft.com.cn/article/dohiggs.html