| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 707 人关注过本帖
标题:这个程序为什么很不稳定,有时候成功有时候执行错误
只看楼主 加入收藏
llp108
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2007-11-15
结帖率:25%
收藏
 问题点数:0 回复次数:3 
这个程序为什么很不稳定,有时候成功有时候执行错误
对n个整数进行排序的程序
#include "stdio.h"
#define N 100
main()
{void sort(int**p,int n);
 int a[N],i,*p[N],**pointer,n;
 printf("请输入要对几个数进行排序:");
 scanf("%d",&n);
 printf("请输入要排序的数:\n");
 for(i=0;i<n;i++)
     p[i]=a+i;
 for(i=0,pointer=p;i<n;i++,pointer++)
     scanf("%d",*pointer);
 pointer=p;//在进行函数处理前先让其回到初始地点//   
 sort(pointer,n);   
}
void sort(int**p,int n)
{int i,j,*temp;
 for(j=1;j<n;j++)
    {for(i=0;i<n-j;i++)
        if(**p>=**(p+1))
          {temp=*p;*p=*(p+1);*(p+1)=temp;p++;}
     p=p-(n-j);}  //每比完1论让指针回归//   
 printf("排序后的数字顺序是:\n");
 for(i=0;i<n;i++)
     printf("%d  ",**p++);
}
2007-12-30 13:20
布拉莫斯
Rank: 1
来 自:中国太平洋舰队
等 级:新手上路
帖 子:169
专家分:0
注 册:2007-3-31
收藏
得分:0 
for(i=0,pointer=p;i<n;i++,pointer++)
     scanf("%d",*pointer);
楼主没有为 pointer所代表的一块内存申请空间,所以其读写操作是可以视为非法的。。

真理往往掌握在少数人手中,可现实却是少数服从多数!
2007-12-30 23:15
dsjdcy
Rank: 1
等 级:新手上路
帖 子:31
专家分:0
注 册:2007-12-2
收藏
得分:0 
int a[N],i,*p[N],**pointer,n;
这几个变量中,除了n用scanf()赋值了,其它的既没初始化,也没对其赋值,所以它们的值都是不确定的,能运行算是运气很好了!!!

有兴趣共同学习的加QQ287624635 !或E-main至dsjdcy@
2007-12-31 09:31
xianshizhe111
Rank: 1
等 级:新手上路
帖 子:1451
专家分:0
注 册:2007-12-8
收藏
得分:0 
单级间址,已经够复杂的拉!何况二级间址.
2007-12-31 17:12
快速回复:这个程序为什么很不稳定,有时候成功有时候执行错误
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023391 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved