集合和数组的排序算法

package com.varicom.test.test;

import java.util.List;

import org.junit.Test;

import com.google.common.collect.Lists;

public class SortTest {

	@Test
	public void testSort() {// 10,8,5,25,1000,1
		List<SortObject> list = Lists.newArrayList();
		list.add(new SortObject(10));
		list.add(new SortObject(8));
		list.add(new SortObject(5));
		list.add(new SortObject(25));
		list.add(new SortObject(1000));
		list.add(new SortObject(1));
		list.add(new SortObject(6));
		showData(list);
		sort(list);
		showData(list);
	}

	public void showData(List<SortObject> list) {
		for (int i = 0; i < list.size(); i++) {
			System.out.print(list.get(i).getAge() + ",");
		}
		System.out.println();
	}

	public void sort(List<SortObject> list) {
		for (int i = 0; i < list.size() - 1; i++) {
			if (list.get(i).compareTo(list.get(i + 1)) > 0) {// 要调换位置
				changePosition(list, i, i + 1);
				for (int j = i; j > 0; j--) {
					if (list.get(j - 1).compareTo(list.get(j)) > 0) {
						changePosition(list, j - 1, j);
					} else {
						break;
					}
				}
			}
		}
	}

	public void changePosition(List<SortObject> list, int i, int j) {
		SortObject temp = null;
		temp = list.get(i);
		list.set(i, list.get(j));
		list.set(j, temp);
	}

}
package com.varicom.test.test;

public class SortObject {

	private int age;


	public SortObject() {
		super();
	}

	public SortObject(int age) {
		super();
		this.age = age;
	}

	public int getAge() {
		return age;
	}

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

	public int compareTo(SortObject o) {
		System.out.println("a:" + this.age + ",b:" + o.age + " =:" + (this.age - o.age));
		return this.age - o.age;
	}
}


转载于:https://my.oschina.net/u/2247227/blog/607519

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值