c语言中如何使返回值为数组
例如intMerge1(intb[],intb1[],ints,intm,intt){inti,j,k;i=s;j=m+1;k=s;while(i<=m&&j<=t){/...
例如
int Merge1 (int b[ ], int b1[ ], int s, int m, int t )
{
int i,j,k;
i=s; j=m+1; k=s;
while (i<=m && j<=t)
{ //两表中元素比较
if (b[i]<=b[j]) b1[k++]=b[i++];
else b1[k++]=b[j++];
}
while (i<=m) b1[k++]=b[i++]; //前一个子序列剩下的
while (j<=t) b1[k++]=b[j++]; //后一个子序列剩下的
return b1;
}
如何改才能 返回 一个 int b的数组
来人帮帮忙 啊
~~~
int merge(int b[],int n)
{
int k=0,i,m=0,ans=0;
for(k=0;k<(n-1)/2;k++)
for(i=0;i<n;i=(2*i+2^k))
{
if(b[i]>b[i+2^k])
ans++;
Merge1(b,b1,i,i+2^k,2*i+2^k);
for(m=0;m<(2*i+2^k);m++)
{
b[m]=b1[m];
}
}return ans;
}
这个函数中要用到使b=b1数组 这样写 哪里有错啊 展开
int Merge1 (int b[ ], int b1[ ], int s, int m, int t )
{
int i,j,k;
i=s; j=m+1; k=s;
while (i<=m && j<=t)
{ //两表中元素比较
if (b[i]<=b[j]) b1[k++]=b[i++];
else b1[k++]=b[j++];
}
while (i<=m) b1[k++]=b[i++]; //前一个子序列剩下的
while (j<=t) b1[k++]=b[j++]; //后一个子序列剩下的
return b1;
}
如何改才能 返回 一个 int b的数组
来人帮帮忙 啊
~~~
int merge(int b[],int n)
{
int k=0,i,m=0,ans=0;
for(k=0;k<(n-1)/2;k++)
for(i=0;i<n;i=(2*i+2^k))
{
if(b[i]>b[i+2^k])
ans++;
Merge1(b,b1,i,i+2^k,2*i+2^k);
for(m=0;m<(2*i+2^k);m++)
{
b[m]=b1[m];
}
}return ans;
}
这个函数中要用到使b=b1数组 这样写 哪里有错啊 展开
4个回答
展开全部
1、注意C/C++不能直接返回一个数组。这是由于在C/C++中,数组不是一种类型,因此不能被直接返回。
2、在C/C++中,一般有两种方法来返回一个数组。
第一种方法:
返回一个指向数组的指针,例如char (*retArray)[10]声明了一个函数retArray,该函数可以返回指向具有10个char元素的数组例子如下:#include#includeint (*retArray())[10]{int (*a)[10];int i=0;/*动态开辟空间*/
a=calloc(10,sizeof(int));/*赋值*/for(i=0;i<10;i++){(*a)[i]=i;}return a;}int main(){int (*b)[10];
/*函数返回指向数组的指针*/
b=retArray();
/*打印第一个元素*/
printf("%d/n",(*b)[0]);
/*释放空间*/free(b);return 0;}第二种方法:
如果你不喜欢用指针的形式返回数组,那么可以采用返回一个结构的形式。这种形式相对较安全,可以避免忘记释放指针而造成内存泄露,也可以避免访问悬挂指针造成的错误。但缺点是由于结构是先拷贝再返回,因此如果结构较大时,会影响效率和占用较大内存。
例子如下:#includestruct tag{int a[10];}x,y;struct tag retArray(){int i=0;for(i=0;i<10;i++)
x.a[i]=i;return x;}int main(){struct tag y=retArray();
printf("%d/n",y.a[3]);return 0;}注意:(1)在返回指针时要切记要避免内存泄露和访问悬挂指针。
(2)很多人认为指针和数组等价的,这是错误的。int (*a)[10]和int b[10]两者是不能直接用a=b来赋值的。在数组和指针作为函数参数传递时,二者可以认为等价,这是因为数组会被转化为指针来传递。
(3)返回多维数组方法类似。
2、在C/C++中,一般有两种方法来返回一个数组。
第一种方法:
返回一个指向数组的指针,例如char (*retArray)[10]声明了一个函数retArray,该函数可以返回指向具有10个char元素的数组例子如下:#include#includeint (*retArray())[10]{int (*a)[10];int i=0;/*动态开辟空间*/
a=calloc(10,sizeof(int));/*赋值*/for(i=0;i<10;i++){(*a)[i]=i;}return a;}int main(){int (*b)[10];
/*函数返回指向数组的指针*/
b=retArray();
/*打印第一个元素*/
printf("%d/n",(*b)[0]);
/*释放空间*/free(b);return 0;}第二种方法:
如果你不喜欢用指针的形式返回数组,那么可以采用返回一个结构的形式。这种形式相对较安全,可以避免忘记释放指针而造成内存泄露,也可以避免访问悬挂指针造成的错误。但缺点是由于结构是先拷贝再返回,因此如果结构较大时,会影响效率和占用较大内存。
例子如下:#includestruct tag{int a[10];}x,y;struct tag retArray(){int i=0;for(i=0;i<10;i++)
x.a[i]=i;return x;}int main(){struct tag y=retArray();
printf("%d/n",y.a[3]);return 0;}注意:(1)在返回指针时要切记要避免内存泄露和访问悬挂指针。
(2)很多人认为指针和数组等价的,这是错误的。int (*a)[10]和int b[10]两者是不能直接用a=b来赋值的。在数组和指针作为函数参数传递时,二者可以认为等价,这是因为数组会被转化为指针来传递。
(3)返回多维数组方法类似。
展开全部
这是传址,不需要返回
void Merge1 (int b[ ], int b1[ ], int s, int m, int t )
{
int i,j,k;
i=s; j=m+1; k=s;
while (i<=m && j<=t)
{ //两表中元素比较
if (b[i]<=b[j]) b1[k++]=b[i++];
else b1[k++]=b[j++];
}
while (i<=m) b1[k++]=b[i++]; //前一个子序列剩下的
while (j<=t) b1[k++]=b[j++]; //后一个子序列剩下的
}
void Merge1 (int b[ ], int b1[ ], int s, int m, int t )
{
int i,j,k;
i=s; j=m+1; k=s;
while (i<=m && j<=t)
{ //两表中元素比较
if (b[i]<=b[j]) b1[k++]=b[i++];
else b1[k++]=b[j++];
}
while (i<=m) b1[k++]=b[i++]; //前一个子序列剩下的
while (j<=t) b1[k++]=b[j++]; //后一个子序列剩下的
}
追问
int merge(int b[],int n)
{
int k=0,i,m=0,ans=0;
for(k=0;kb[i+2^k])
ans++;
Merge1(b,b1,i,i+2^k,2*i+2^k);
for(m=0;m<(2*i+2^k);m++)
{
b[m]=b1[m];
}
}return ans;
}
这个函数中要用到使b=b1数组 这样写 哪里有错啊。。。
追答
2^k这都是什么?
2的k次方吗?
应该是pow(2, k);
pow函数包含在math.h头文件中
你把所有的代码贴上来,要求是什么给我说下,我帮你整体改一下
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int Merge1 (int b[ ], int b1[ ], int s, int m, int t )改成int *Merge1 (int b[ ], int b1[ ], int s, int m, int t )
就是int 后面加*,这样就可以了
就是int 后面加*,这样就可以了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
函数返回值一般为一个值,现在你要返回数组,那么你可以在程序中定义全局数组,或者你通过传指针的方式传过来数组参数,在函数中更改了数组的值后又把数组首地址返回去就可以用了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询