冒泡排序for(i=0;i<n-1;i++) for(j=0;j<n-i-1;j++) if(arr[j+1]<arr[j]) 这个程序是怎样降序排序?

比如说我要让1到10的降序,这两个FOR是分别如何比较?请详细说明。不要程序,只想各位知友能用文字详细说明这两个FOR如何比较。... 比如说我要让1到10的降序,这两个FOR是分别如何比较?请详细说明。
不要程序,只想各位知友能用文字详细说明这两个FOR如何比较。
展开
 我来答
zh857872
2013-10-12 · TA获得超过1415个赞
知道小有建树答主
回答量:426
采纳率:100%
帮助的人:343万
展开全部
楼主,分析如下:
for(i=0;i<n-1;i++)
//第一个循环,控制完成排序的轮数

for(j=0;j<n-i-1;j++)
//第二个循环,控制每轮排序需要比较的次数,其中的n-i-1,为什么要-i,因为冒泡排序每轮过后,都会把最大的放在了数据的后面(升序)或者前面(降序),也就是后面的i个数(或前面的i个数)已经是排好序的了,为减少比较次数,故-i

if(arr[j+1]<arr[j])
//这个判断条件是用来控制是升序还是降序排列的

完整的程序如下:
public class BubbleSort
{

public static void main(String[] args)
{
int[] a = {6,9,5,4,8,3,10,1,2,7};
bubbleSort(a);
for(int i=0;i<a.length;i++)
{
System.out.print(a[i] + "\t");
}
}

public static void bubbleSort(int[] a)
{
boolean flag = true;
while(flag)
{
flag = false;
for(int i=0;i<a.length-1;i++)
{
if(a[i] < a[i+1])
{
int temp = a[i];
a[i] = a[i+1];
a[i+1] = temp;
flag = true;
}
}
}
}
}
自己运行就OK了。

有问题欢迎提问,满意请采纳!
更多追问追答
追问
如何比较?1到10,你打个比方,比如第一个和第二个FOR首次循环指到哪里?for(i=0;i<n-1;i++) for(j=0;j<n-i-1;j++) if(arr[j+1]<arr[j])   使用这三段程序回答。
追答
分析如下:
for(i=0;i<n-1;i++)
//第一个循环,控制完成排序的轮数

for(j=0;j<n-i-1;j++)
//第二个循环,控制每轮排序需要比较的次数,其中的n-i-1,为什么要-i,因为冒泡排序每轮过后,都会把最大的放在了数组的后面(升序)或者前面(降序),也就是后面的i个数(或前面的i个数)已经是排好序的了,为减少比较次数,故-i

if(arr[j+1]<arr[j])
//这个判断条件是用来控制是升序还是降序排列的
八果时0n
2013-10-12 · 超过19用户采纳过TA的回答
知道答主
回答量:75
采纳率:0%
帮助的人:52.8万
展开全部
定义参数 temp
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i-1; j++) {
if (arr[j + 1] > arr[j])
{
temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
}
追问
完整的程序我也有,唯独两个FOR循环如何执行不明白,请这位好心人详细说明下。比如说首次循环,第一个和第二个FOR指到哪里?然后如何比较?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式