欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Java如何對復(fù)雜的數(shù)據(jù)類型排序和比大小

 更新時間:2023年12月09日 14:13:17   作者:luming.02  
我相信大家在第一次接觸算法的時候,最先接觸的肯定也是從排序算法開始的,下面這篇文章主要給大家介紹了關(guān)于使用Java如何對復(fù)雜的數(shù)據(jù)類型排序和比大小的相關(guān)資料,需要的朋友可以參考下

一.對復(fù)雜的數(shù)據(jù)類型比大小

假如我們現(xiàn)在有個學(xué)生類,并且我們實例化出了倆個學(xué)生對象,他們各自有各自的名字和年齡屬性,我們?nèi)绾螌λ麄冞M行比大小操作呢?

class Student {
    public String name;
    public int age;
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
}
 
public class Test{
    public static void main(String[] args) {
        Student student1 = new Student("張三",20);
        Student student2 = new Student("李四",23);   
        if (student1 > student2) {
            System.out.println("student1 > student2");
        }else {
            System.out.println("student1 < student2");
        }
    }
}

我們可以看見編譯器的報錯提示,這是因為Java提供的運算符號只能識別操作簡單的數(shù)據(jù)類型,對于我們自定義的Student類是無法識別的

Comparable接口

在這種情況下,我們就可以使用我們之前的講解的接口的知識,我們可以調(diào)用Comparable接口,然后重寫其中的compareTo方法,在使用接口的時候需要注意聲明你需要比較的類型,也就是接口后尖括號內(nèi)的內(nèi)容

compareTo方法 

我們在這里對接口中的compareTo方法進行重寫后,在main方法中進行調(diào)用 

class Student implements Comparable <Student> {
    public String name;
    public int age;
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
    @Override
    public int compareTo(Student o) {
        return this.name.compareTo(o.name);
    }
}
 
public class Test{
 
    public static void main(String[] args) {
        Student student1 = new Student("張三",20);
        Student student2 = new Student("李四",23);
 
        if (student1.compareTo(student2) > 0) {
            System.out.println("student1 > student2");
        }else {
            System.out.println("student1 <= student2");
        }
    }
}

我們也可以根據(jù)年齡進行比大小,只需要重新重寫這個方法就可以了

    @Override
    public int compareTo(Student o) {
        return this.age-o.age;
    }

二.對復(fù)雜數(shù)據(jù)類型排序

假如我們現(xiàn)在有一個學(xué)生類數(shù)組,我們使用Arrays.sort對他進行排序

public class Test{
 
    public static void main(String[] args) {
        Student[] students = new Student[3];
        Student student1 = new Student("張三",20);
        Student student2 = new Student("李四",23);
        Student student3 = new Student("王五",25);
        students[0] = student1;
        students[1] = student2;
        students[2] = student3;
        
        Arrays.sort(students);
      
    }
}

我們會發(fā)現(xiàn)報錯信息如下,原因就是對于這種復(fù)雜的數(shù)據(jù)類型,如果我們要讓編譯器來排序,那我們就需要給他排序規(guī)則,很顯然這里編譯器是沒有讀取到任何的排序規(guī)則的

我們點擊錯誤信息,打開源碼觀察會發(fā)現(xiàn),編譯器這里還是用到了Comparable接口

那我們還是像剛才一樣調(diào)用Comparable接口,然后我們給出明確的排序規(guī)則,再寫一個排序方法,就可以正常對復(fù)雜數(shù)據(jù)排序了

import java.util.Arrays;
 
class Student implements Comparable <Student> {
    public String name;
    public int age;
    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }
//    @Override
//    public int compareTo(Student o) {
//        return this.name.compareTo(o.name);
//    }
    @Override
    public int compareTo(Student o) {
        return this.age-o.age;
    }
    
    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
 
    public static void mySort(Comparable[] comparables) {
 
        for (int i = 0; i < comparables.length-1; i++) {
            for (int j = 0; j < comparables.length-1-i; j++) {
                //if(comparables[j] > comparables[j+1]) {
                if(comparables[j].compareTo(comparables[j+1]) > 0) {
                    //交換
                    Comparable tmp = comparables[j];
                    comparables[j] = comparables[j+1];
                    comparables[j+1] = tmp;
                }
            }
        }
    }
}
 
public class Test{
 
    public static void main(String[] args) {
        Student[] students = new Student[3];
        Student student1 = new Student("張三",20);
        Student student2 = new Student("李四",23);
        Student student3 = new Student("王五",25);
        students[0] = student1;
        students[1] = student2;
        students[2] = student3;
        
        mySort(students);
        System.out.println(Arrays.toString(students));
       
    }
}

三.總結(jié)

當(dāng)我們需要對復(fù)雜的數(shù)據(jù)類型進行排序或者比大小的時候,我們就可以使用Comparable接口,然后重寫其中的compareTo方法,然后就可以直接使用compareTo方法進行排序了,又或者是通過其他方法來調(diào)用compareTo方法來對復(fù)雜類型的數(shù)組進行排序

到此這篇關(guān)于使用Java如何對復(fù)雜的數(shù)據(jù)類型排序和比大小的文章就介紹到這了,更多相關(guān)Java數(shù)據(jù)類型排序和比大小內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論