package 数组;
/**
* 对给定的数组进行排序
* {5,1,6,4,2,8,9}
* 思想:排序肯定要遍历数组,肯定是for循环(大圈套小圈)
冒泡排序
1、先从头角标相邻两个元素之间进行比较,将较大值存放在后一个元素中,然后再与后一个元素的进行比较,直至最大值存放到最后一个元素中。
2、再重复1操作,每次计较次数减一,一圈比完后存放的较大元素不再参与比较。
* 冒泡排序是相邻的两个数进行比
*/
public class 数组冒泡排序
{
public static void maoPao(int[]arr)
{
for(int x=0;x<arr.length;x++)
{
for(int y=0;y<arr.length-x-1;y++)//-x:让每一次比较的元素减少 -1:避免角标越界
{
if(arr[y]>arr[y+1])//拿内循环0角标的数比内循环1角标的数,如果大于就换位置
{
int temp=arr[y];
arr[y]=arr[y+1];
arr[y+1]=temp;
}
}
}
}
public static void daYin(int[]arr)//打印输出函数
{
for(int x=0;x<arr.length;x++)
{
if(x!=arr.length-1)
System.out.print(arr[x]+",");
else
System.out.println(arr[x]);
}
}
public static void main(String[] args)
{
int [] arr={5,1,6,4,2,8,9};
daYin(arr);//排序前
maoPao(arr);//冒泡排序
daYin(arr);//排序后
}
}
|
|