Java语言程序设计(第十版) 第十三章 第3题

13.3

排序 ArrayList

import java.util.ArrayList;

class Sort {
    ArrayList<Number> list = new ArrayList<Number>();

    public Sort() {}
    public Sort(ArrayList<Number> list) {
        this.list = list;
    }
    public static void sort(ArrayList<Number> list) {
        if (list.size() == 0 || list == null)
            return ;
        for (int i = list.size()-1; i >= 0; i--) { //这里简单的冒泡排序,其他大同小异
            for (int j = 0; j < i; j++) {
                if (list.get(j).doubleValue() > list.get(j+1).doubleValue()) {
                    int index = j;
                    Number m = list.get(j);
                    list.set(index, list.get(j+1));
                    list.set(j+1, m);
                }
            }
        }
    }
}

测试


public class Test13_3 {
    public static void main(String[] args) {
        Sort s = new Sort();
        s.list.add(199);
        s.list.add(89);
        s.list.add(90);
        s.list.add(1299);
        s.list.add(829);
        s.list.add(920);
        s.list.add(2.2);
        s.list.add(2.0);
//      s.sort(s.list);
        Sort.sort(s.list);
        for (Number tem: s.list) {
            System.out.println(tem);
        }
    }
}

结果

2.0
2.2
89
90
199
829
920
1299

类图:

这里写图片描述

猜你喜欢

转载自blog.csdn.net/qq_37131037/article/details/80719856
今日推荐