| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 584 人关注过本帖
标题:[求助]纠错 冒泡法问题
只看楼主 加入收藏
hago
Rank: 1
等 级:新手上路
帖 子:52
专家分:0
注 册:2007-11-3
收藏
 问题点数:0 回复次数:11 
[求助]纠错 冒泡法问题
#include<stdio.h>
void maoposort(int a[],int n)
{
int i,j,t;
for(j=n;j>=1;j--)
{
for(i=1;i<=j-1;i++)
{
if (a[i]>a[i+1])
{t=a[i];a[i]=a[i+1];a[i+1]=t;}
}

}
}
void main()
{
int array[10]={1,2,54,21,8,78,65,47,0,4},m;
maoposort(array,10);
for(m=1;m<=10;m++)
printf("%4d",array[m]);
}
我想用冒泡法排序的
为什运行结果却是0 2 4 8 21 47 54 65 78 575
为什么还会有 575
而1却不见了
哪位高手指导下 谢谢
搜索更多相关主题的帖子: 纠错 冒泡 
2007-11-04 10:13
酷儿
Rank: 1
等 级:新手上路
帖 子:23
专家分:0
注 册:2007-10-15
收藏
得分:0 

#include<stdio.h>
void maoposort(int a[],int n)
{
int i,j,t;
for(j=n;j>=1;j--)
{
for(i=0;i<=j-1;i++)
{
if (a[i]>a[i+1])
{t=a[i];a[i]=a[i+1];a[i+1]=t;}
}

}
}
void main()
{
int array[10]={1,2,54,21,8,78,65,47,0,4},m;
maoposort(array,10);
for(m=1;m<=10;m++)
printf("%4d",array[m]);
}

数组下标由0开始

2007-11-04 10:21
作弊
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-11-3
收藏
得分:0 

2个问题
第一个问题是
for(i=1;i<=j-1;i++)
i 从1开始 那么 a[i] 是2 你的排序一开始就跳过了 a[0] 也就是没计算1

第二个问题是
if (a[i]>a[i+1])
在第一次运行for(j=n;j>=1;j--) 的时候
i+1 在最后一次 for(i=1;i<=j-1;i++) 循环中 变成了 j 超界了 这样 读取了一个数组之外的内存地址

建议修改成

for(i=0;i<=j-1;i++)

if ((a[i]>a[i+1])&&(i+1<j))

2007-11-04 10:40
作弊
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-11-3
收藏
得分:0 
建议初学 sorting 之类的用 java

那个会避免出现内存问题
2007-11-04 10:41
酷儿
Rank: 1
等 级:新手上路
帖 子:23
专家分:0
注 册:2007-10-15
收藏
得分:0 

建议修改成

for(i=0;i<=j-1;i++)

if ((a[i]>a[i+1])&&(i+1<j))



已经有了i=0,i<j-1还会越界吗??多余!!!

2007-11-04 10:43
hago
Rank: 1
等 级:新手上路
帖 子:52
专家分:0
注 册:2007-11-3
收藏
得分:0 

我明白啦 谢谢拉啊
但你给出的有点问题啊 我改过来了 能正常运行的
#include<stdio.h>
void maoposort(int a[],int n)
{
int i,j,t;
for(j=n-1;j>=0;j--)
{
for(i=0;i<=j-1;i++)
{
if (a[i]>a[i+1])
{t=a[i];a[i]=a[i+1];a[i+1]=t;}
}

}
}
void main()
{
int array[10]={1,2,54,21,8,78,65,47,0,4},m;
maoposort(array,10);
for(m=0;m<=9;m++)
printf("%4d",array[m]);
}

2007-11-04 10:45
作弊
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-11-3
收藏
得分:0 
i最后是等于 j-1的

而a[i+1] 相当于 a[j-1+1]

第一次的 j=n 那就是 a[n]

n是10 自然 越界了
2007-11-04 10:56
zzj936
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2007-11-4
收藏
得分:0 
学习了,谢谢
2007-11-04 11:04
酷儿
Rank: 1
等 级:新手上路
帖 子:23
专家分:0
注 册:2007-10-15
收藏
得分:0 

谢谢,指出错误啊
我又看了一下,我那个在运行时没错误,是上面的越界和下面的输出正好抵消.

2007-11-04 20:29
xiubing0377
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2007-11-5
收藏
得分:0 
2007-11-05 11:05
快速回复:[求助]纠错 冒泡法问题
数据加载中...
 
   



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

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