| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 786 人关注过本帖
标题:选择法排序的困惑
只看楼主 加入收藏
凌晨
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2004-9-22
收藏
 问题点数:0 回复次数:6 
选择法排序的困惑

#include<stdio.h> main() {int a[11],i,j,k,m; for(i=1;i<11;i++) scanf("%d",a[i]); for(j=1;j<10;j++) {m=j; for(k=j+1;k<11;k++) if(a[m]>a[k]) m=k; if(m!=j) {a[0]=a[m];a[m]=a[j];a[j]=a[0];} } for(i=1;i<11;i++) printf("%d ",a[i]);}

运行后出现-46 0 0 8 32 32 145 158 1289 1490 Null pointer assignment

前各位高手帮帮忙,多谢!

搜索更多相关主题的帖子: 困惑 选择 
2004-10-10 10:21
神vLinux飘飘
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:浙江杭州
等 级:贵宾
威 望:91
帖 子:6140
专家分:217
注 册:2004-7-17
收藏
得分:0 

放心,小错误而已

请注意你的 scanf("%d",a[i]); 你漏写了个& 应该是 scanf("%d",&a[i]);

呵呵,怎么样,是个小错误吧,以后要多小心点哦


淘宝杜琨
2004-10-10 13:09
神vLinux飘飘
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:浙江杭州
等 级:贵宾
威 望:91
帖 子:6140
专家分:217
注 册:2004-7-17
收藏
得分:0 

顺便说一句,数组不是从1开始的,而是从0。

从你的程序来看好象并没有用到a[0] ,这是学习C语言数组的时候的难点之一。要注意。


淘宝杜琨
2004-10-10 13:11
mikewolf
Rank: 1
等 级:新手上路
帖 子:175
专家分:0
注 册:2004-7-3
收藏
得分:0 
高效选择排序当推堆排序!
2004-10-10 13:59
神vLinux飘飘
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:浙江杭州
等 级:贵宾
威 望:91
帖 子:6140
专家分:217
注 册:2004-7-17
收藏
得分:0 
呀[迈克老狼]~

淘宝杜琨
2004-10-10 14:11
凌晨
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2004-9-22
收藏
得分:0 
以下是引用神vLinux飘飘在2004-10-10 13:11:05的发言:

顺便说一句,数组不是从1开始的,而是从0。

从你的程序来看好象并没有用到a[0] ,这是学习C语言数组的时候的难点之一。要注意。

很感谢版主的帮助,但我并不是没有用到a[0],而是将其作为交换单元。


我喜欢充实的感觉,在黑夜与白天的交界处,有我与你一起进取,此生足矣!……
2004-10-10 19:47
神vLinux飘飘
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:浙江杭州
等 级:贵宾
威 望:91
帖 子:6140
专家分:217
注 册:2004-7-17
收藏
得分:0 

呀哈,我也犯了个错误,竟然没注意到~~晕

原来你是用a[0]做哨兵啊


淘宝杜琨
2004-10-10 19:50
快速回复:选择法排序的困惑
数据加载中...
 
   



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

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