java基础入门----Collections1 集合框架工具类

import java.util.*;

class Collections1  //集合框架工具类 
{
	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
	public static void main(String[] args)
	{
		//sortDemo();   //排序方法
		//maxDemo();	//取最大就是去排序完后最后的元素
		//binarySearchDemo(); //折半查找
		/*
		List<String> list = new ArrayList<String>();
		list.add("asdf");
		list.add("ed");
		list.add("vfvf");
		list.add("addee");
		Collections.sort(list);
		sop(list);
		sop(halfSearchDemo(list,"ed"));
		
		Collections.sort(list,new StrLennComparator());
		sop(list);
		sop(halfSearchDemo2(list,"ed",new StrLennComparator()));
		*/
	}
	public static void sortDemo()
	{
		List<String> list = new ArrayList<String>();
		
		list.add("asdf");
		list.add("ed");
		list.add("vfvf");
		list.add("addee");
		
		Collections.sort(list);
		sop(list);
		
		Collections.sort(list,new StrLennComparator());
		sop(list);
	}
	public static void maxDemo()
	{
		List<String> list = new ArrayList<String>();
		list.add("asdf");
		list.add("ed");
		list.add("vfvf");
		list.add("addee");
		Collections.sort(list);
		sop(list);
		sop(Collections.max(list));
		
		Collections.sort(list,new StrLennComparator());
		sop(list);
		sop(Collections.max(list,new StrLennComparator()));
	}
	public static void binarySearchDemo()
	{
		List<String> list = new ArrayList<String>();
		list.add("asdf");
		list.add("ed");
		list.add("vfvf");
		list.add("addee");
		Collections.sort(list);//Collections.sort(list,new StrLennComparator());
		sop(list);
		
		int index = Collections.binarySearch(list, "vfvf"/*,new StrLennComparator()*/);
		sop("index="+index);
	}
	public static int halfSearchDemo(List<String> list, String key)//二半查找原理
	{
		int max,min,mid;
		max = list.size()-1;
		min = 0;
		
		while(min <= max)
		{
			mid = (max+min)/2;
			String str = list.get(mid);
			int num = str.compareTo(key);
			
			if(num>0)
				max = mid-1;
			else if(num<0)
				min = mid+1;
			else
				return mid;
		}
		return -min-1;
	}
	public static int halfSearchDemo2(List<String> list, String key,Comparator<String> cmp)
	{
		int max,min,mid;
		max = list.size()-1;
		min = 0;
		
		while(min <= max)
		{
			mid = (max+min)/2;
			String str = list.get(mid);
			int num = cmp.compare(str, key);
			
			if(num>0)
				max = mid-1;
			else if(num<0)
				min = mid+1;
			else
				return mid;
		}
		return -min-1;
	}
}

class StrLennComparator implements Comparator<String>
{
	public int compare(String s1, String s2)
	{
		if(s1.length() > s2.length())
			return 1;
		if(s1.length() < s2.length())
			return -1;
		return s1.compareTo(s2);
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值