
C语言 编写fun函数 将数组中的数逆序存放
#include"stdio.h"#defineN5intfun(intarr[],intn){inti,temp;for(i=0;i<n/2;++i){temp=arr...
#include "stdio.h"
#define N 5
int fun(int arr[],int n)
{
int i,temp;
for(i=0; i<n/2; ++i)
{
temp=arr[i];
arr[i]=arr[n-1-i];
arr[n-1-i]=temp;
}
return 1;
}
main()
{
int a[N]={8,6,5,4,1},i;
for(i=0;i<N;i++)
printf("%4d",a[i]);
printf("\n");
fun(a,N);
for(i=0;i<N;i++)
printf("%4d",a[i]);
}
fun函数为什么写成下面这样输出结果还是顺序的呢?请大神答疑。。
int fun(int arr[],int n)
{
int i,r[5];
for(i=0; i<n; ++i)
r[i]=arr[n-1-i];
return *r;
} 展开
#define N 5
int fun(int arr[],int n)
{
int i,temp;
for(i=0; i<n/2; ++i)
{
temp=arr[i];
arr[i]=arr[n-1-i];
arr[n-1-i]=temp;
}
return 1;
}
main()
{
int a[N]={8,6,5,4,1},i;
for(i=0;i<N;i++)
printf("%4d",a[i]);
printf("\n");
fun(a,N);
for(i=0;i<N;i++)
printf("%4d",a[i]);
}
fun函数为什么写成下面这样输出结果还是顺序的呢?请大神答疑。。
int fun(int arr[],int n)
{
int i,r[5];
for(i=0; i<n; ++i)
r[i]=arr[n-1-i];
return *r;
} 展开
4个回答
展开全部
你是想按倒序重新放到一个数组里 然后将数组地址返回是吧,想法不错 但上面代码实现不了的。因为你的数组r[5]的生命周期是在fun函数运行期间,当函数调用结束返回时,这个函数的栈清空,数组r[5]也就不存在了。
追问
不懂什么是函数的栈。。
除了上面的方法,还有其他简单的方法编写吗?
追答
反正意思就是fun函数调用结束后,fun里定义的变量,包括数组啥的就都被释放了,就都不能用了。 别的方法么 动态分配内存就行了,动态分配的内存在函数调用结束后并不会释放,一直到你用free主动释放后才失效。
可以改为下面代码:
#include "stdio.h"
#include <stdlib.h>
#define N 5
int fun(int arr[],int n)
{
int i,temp;
for(i=0; i<n/2; ++i)
{
temp=arr[i];
arr[i]=arr[n-1-i];
arr[n-1-i]=temp;
}
return 1;
}
int *funDyMalloc(int arr[],int n);
main()
{
int a[N]= {8,6,5,4,1},i;
int *p;
for(i=0; i<N; i++)
printf("%4d",a[i]);
printf("\n");
p=funDyMalloc(a,N);
for(i=0; i<N; i++)
printf("%4d",b[i]);
free(b);
}
int *funDyMalloc(int arr[],int n)
{
int i;
int *ptr=(int *)malloc(n*sizeof(int));
for(i=0; i<n; ++i)
ptr[i]=arr[n-1-i];
return ptr;
}
展开全部
r只存在于fun内、fun函数结束后,r所分配的内存也随之释放
用动态分配内存可解决此问题、如下
#include "stdio.h"
#include <stdlib.h>
#define N 5
int* fun(int arr[],int n)
{
int i,*r;
r=(int*)malloc(sizeof(int)*5);
for(i=0; i<n; ++i)
r[i]=arr[n-1-i];
return r;
}
void main()
{
int a[N]={8,6,5,4,1},i,*b;
for(i=0;i<N;i++)
printf("%4d",a[i]);
printf("\n");
b=fun(a,N);
for(i=0;i<N;i++)
printf("%4d",b[i]);
free(b);
}
----------------------------------------------
malloc分配的内存不随函数生命周期的结束而释放
使用完所分配的内存后记得使用free函数释放
用动态分配内存可解决此问题、如下
#include "stdio.h"
#include <stdlib.h>
#define N 5
int* fun(int arr[],int n)
{
int i,*r;
r=(int*)malloc(sizeof(int)*5);
for(i=0; i<n; ++i)
r[i]=arr[n-1-i];
return r;
}
void main()
{
int a[N]={8,6,5,4,1},i,*b;
for(i=0;i<N;i++)
printf("%4d",a[i]);
printf("\n");
b=fun(a,N);
for(i=0;i<N;i++)
printf("%4d",b[i]);
free(b);
}
----------------------------------------------
malloc分配的内存不随函数生命周期的结束而释放
使用完所分配的内存后记得使用free函数释放
追问
你的答案不懂= =
这学期刚学的C语言= = 就学到数组和指针。
解释明白了。这是我们期末考试一道题o(╥﹏╥)o
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
for(i=0; i<n; ++i) 应该是i<n/2吧,一共5个数,你换5次当然又回到原来的样子了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
因为n从头到尾走了一遍 其实只能走一半
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询