JAVA实现冒泡法升序排列问题

代码如下,我看了很多代码,感觉都一样啊,为什么运行结果就是降序或者乱序呢??而且有时候还会少一个数,怎么回事啊?classRank1{publicstaticvoidma... 代码如下,我看了很多代码,感觉都一样啊,为什么运行结果就是降序或者乱序呢??而且有时候还会少一个数,怎么回事啊?class Rank1{ public static void main(String args[]){ int arr[]={10,9,8,7,6,5,4,3,2,1}; int i=0,j=0; for(i=0;i<10;i++){ int temp=0; for(j=i+1;j<10-i;j++){ if(arr[i]>arr[i+1]){ temp=arr[i]; arr[i]=arr[i+1]; arr[i+1]=temp; } } System.out.print(arr[i]); } } } 展开
 我来答
zxq778810
2012-01-06 · TA获得超过164个赞
知道答主
回答量:187
采纳率:0%
帮助的人:83.7万
展开全部
int arr[] = { 10, 9, 8, 7, 6, 5, 4, 3, 2, 1 };
int i = 0, j = 0;
int temp = 0;
for (i = 0; i < 9; i++) {
for (j = 0; j < 9 - i; j++) { // 注意冒泡是从下往上冒,所以j=0;j<9-i
// 是因为j不能超过8,超过就会出错,j+1=10越界
if (arr[j] > arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
System.out.println("***************************************");
for (i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
System.out.println("***************************************");
建议你把排序的原理和你自己的解决思路理清楚,不要着急写代码,思路清晰了,代码是很容易实现的。
以下是网上资料:
冒泡排序(BubbleSort)的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。至此第一趟结束,将最大的数放到了最后。在第二趟:仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再小于第2个数),将小数放前,大数放后,一直比较到倒数第二个数(倒数第一的位置上已经是最大的),第二趟结束,在倒数第二的位置上得到一个新的最大数(其实在整个数列中是第二大的数)。如此下去,重复以上过程,直至最终完成排序。

  由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。
cpygogogo
2012-01-06 · 超过43用户采纳过TA的回答
知道答主
回答量:116
采纳率:0%
帮助的人:97.8万
展开全部
改后程序如下
class Rank1{
public static void main(String args[]){
int arr[]={10,9,8,7,6,5,4,3,2,1};
int i=0,j=0;
int temp;
for(i=0;i<10;i++){
for(j=i+1;j<10;j++){
if(arr[i]>arr[j]){
temp=arr[i];
arr[i]=arr[j];
arr[j]=temp;
}
}
System.out.print(arr[i]);
}

}

}
建议看看排序的原理而不要只追求代码的一致,等你能用自然语言表述明白的时候写代码肯定不成问题!
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cqlfoxufo230
2012-01-06
知道答主
回答量:17
采纳率:0%
帮助的人:20.6万
展开全部
public class Rank1 {
public static void main(String args[]) {
int arr[] = { 10, 9, 8, 7, 6, 5, 4, 3, 2, 1 };
int i = 0, j = 0;

for (i = 0; i < 10; i++) {
int temp = 0;
for (j = i + 1; j < 10 ; j++) { //循环次数
if (arr[i] > arr[i + 1]) {
temp = arr[i];
arr[i] = arr[i + 1];
arr[i + 1] = temp;
}
}

}

for(int aa=0;aa<arr.length;aa++){
System.out.print(arr[aa]+",");
}

}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式