首页 > 编程语言 > 详细

对象的插入排序

时间:2017-11-21 10:28:24      阅读:156      评论:0      收藏:0      [点我收藏+]
/*
 * objectSort.java
 * demonstrate sorting objects (use insertion sort)
 */
public class Person {
    private String firstname;
    private String lastname;
    private int age;
    
    // constructor
    public Person(String lastname, String firstname, int age) {
        this.lastname = lastname;
        this.firstname = firstname;
        this.age = age;
    }
    
    // get lastname
    public String getLast() {
        return lastname;
    }
    
    // display
    public void displayPerson() {
        System.out.print(" Lastname:" + lastname);
        System.out.print(" Firstname:" + firstname);
        System.out.print(" Age:" + age);
    }
}
//end class Person
// ---------------------------
public class ArrayInOb {
    private Person[] a;
    private int nElems;
    
    // constructor
    public ArrayInOb(int max) {
        a = new Person[max];
        nElems = 0;
    }
    
    // put element to array
    public void insert(String lastname, String firstname, int age) {
        a[nElems] = new Person(lastname, firstname, age);
        nElems++;
    }
    
    // display
    public void display() {
        for (int j = 0; j < nElems; j++) {
            a[j].displayPerson();
            System.out.println("");
        }
    }
    
    // insert sort
    public void insertSort() {
        int in, out;
        
        for (out = 1; out < nElems; out++) {
            Person temp = a[out];
            in = out;
            
            int compare = a[in-1].getLast().compareTo(temp.getLast());
            while (in > 0 && compare > 0) {
                // shift item to right
                a[in] = a[in-1];
                // go left one position
                --in;           
            }
            // insert marked item
            a[in] = temp;
        }
    }
}
// end class ArrayInOb
// ---------------------------
public class ObjectSortApp {
    
    public static void main(String[] args) {
        int maxSize = 100;
        ArrayInOb arr;
        arr = new ArrayInOb(maxSize);
        
        // put elements into array
        arr.insert("Evans", "Zatty", 24);
        arr.insert("Bvans", "Aatty", 21);
        arr.insert("Avans", "Yatty", 5);
        arr.insert("Tvans", "Xatty", 99);
        
        System.out.println("Before Sorting:");
        arr.display();
        
        System.out.println("After Sorting:");
        arr.insertSort();
        arr.display();
    }
}

对象的插入排序

原文:http://www.cnblogs.com/mmsumz/p/7871815.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!