选择排序+冒泡排序

排序

**Comparable接口:**java提供的用来定义排序规则的接口

/**
 * 定义一个学生类,具有姓名和年龄两个属性,通过Comparable接口提供比较规则
 */
public class Student implements Comparable<Student>{
    private String username;
    private int age;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public int compareTo(Student o) {
        return this.getAge()-o.getAge();
    }
}
//测试类
public class TestComparable {
    public static void main(String[] args) {
        //创建两个Student对象,调用getMax完成测试
        Student s1 = new Student();
        Student s2 = new Student();
        s1.setAge(15);
        s1.setUsername("王");
        s2.setAge(20);
        s2.setUsername("张");
        getMax(s1,s2);
    }
    public static Comparable getMax(Comparable c1,Comparable c2){
        int result = c1.compareTo(c2);
        //result>0,则c1比c2大
        if(result>=0) return c1;
        else return c2;
    }
}

冒泡排序

冒泡排序:比较数组中相邻的两个元素,将小数或大数往前移或后移。冒泡排序嵌套两层循环,时间复杂度为O(n^2),外层表示冒泡的轮数,里层进行依次比较。

将数组从大到小排序

/**
 * 测试冒泡排序
 */
public static int[] sort1(int[] array){
    int temp=0;
    //外层循环,判断要走多少次 length-1防止溢出
    for (int i = 0; i < array.length-1; i++) {
        //-i是因为每次会找出一个最大数
        for (int j = 0; j < array.length-1-i; j++) {
            //如果第二个数比第一个数大则交换位置
            if(array[j+1]>array[j]){
                temp=array[j];
                array[j]=array[j+1];
                array[j+1]=temp;
            }
        }
    }
    return array;
}

如何优化?

定义一个标志位减少没有意义的比较。

public static int[] sort1(int[] array){
    int temp=0;
    //外层循环,判断要走多少次 length-1防止溢出
    for (int i = 0; i < array.length-1; i++) {
        boolean flag = false;
        //-i是因为每次会找出一个最大数
        for (int j = 0; j < array.length-1-i; j++) {
            //如果第一个数比第二个数大则交换顺序
            if(array[j+1]<array[j]){
                temp=array[j];
                array[j]=array[j+1];
                array[j+1]=temp;
                flag = true;
            }
        }
        if (flag==false)
            break;
    }
    return array;
}

选择排序

原理:每一次遍历都选出最小值放或最大值放在合适的位置。

从小到大的排序:找出最小数的索引,将最小数的索引处的值与第一个索引处的值交换
在这里插入图片描述

public static int[] sort2(int[] array){
    for (int i = 0; i < array.length-1; i++) {
        //定义一个变量,记录最小元素所在的索引,默认为参与选择的第一个元素所在的位置
        int min=i;
        for (int j = i+1; j < array.length; j++) {
            //比较最小索引的值与j处的值
            if (array[min]>array[j]){
                min=j; //如果索引min处的值大于j处的值,则将最小索引设为j
            }
        }
        //交换最小元素和i索引的值
        int temp;
        temp=array[i];
        array[i]=array[min];
        array[min]=temp;
    }
    return array;
}

选择排序使用双层循环,外层循环完成数据交换,内层循环做数据比较。

数据比较次数:(n-1)+(n-2)+…+2+1=n^2/2-n/2

数据交换次数:n-1

时间复杂度计算:n2/2-n/2+(n-1)=n2/2+n/2-1

时间复杂度为O(n^2)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值