|  | 
 
| 
问题:
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  原题是把数组逆序存放并输出,我给改成用指针指向数组最后一个元素,p--让指针向前输出
 结果执行却出现了一连串的0,不知道问题出在哪里
 补充一句,调用reserve之前全部正常
 
 代码如下
 
 复制代码#include<stdio.h>
 
int main()
{
        void reverse(int a[],int n);//交换 初始化+定义形参
        int i,a[5]={2,3,6,4,7};
        printf("调换前:\n");
        for(i=0;i<5;i++)
        {
                printf("%d ",a[i]);
        }
        printf("\n");
        printf("调换后:\n");
        reverse(a,5); //格式 函数名(数组,数值)
        return 0;
}
void reverse(int a[],int n)//交换
{
        int *p;
        for(p=a+10;p>=0;p--)
        {
                printf("%d",*p);
        }
}
很正常,估计你是故意这么玩的: 
        for(p=a+10;p>=0;p--) 
        { 
                printf("%d",*p); 
        } 
按照你的循环要求,p从&a后的40个字节的地址,一直不停的减,要减到p=0为止(当然减不到为0就内存溢出了)。
 
一开始输出的时候不是0,是一个随机数,然后也会输出你的逆向数。然后还继续减,减着减着就到输出0了。你可以改下代码自己观察下,把void reverse(int a[],int n);改成如下定义:
 复制代码void reverse(int a[],int n)//交换
{
        
        int *p;
        
        int m=0;        //为了后面限制遇到多少次0后break
        for(p=a+10;p>=0;p--)
        {
                printf("%d\n",*p);
                if(*p==0)
                {
                        m=m+1;
                }
                if(m>10)        //定义遇到多少次0后跳出for
                {
                        break;
                }
                        
        }
        
}
如果你想正常定义,可以修改为:
 复制代码void reverse(int a[],int n)
{
        int *p;
        for(p=a+n-1;p>=a;p--)
        {
                printf("%d",*p);
        }
}
 | 
 
  |