Bootstrap

关于java集合的练习

一、产生10个1-100的随机数,并放到一个数组中,把数组中大于等于10的数字放到一个list集合中,并打印到控制台。

import java.util.*;
class Test
{
	
	public static void main(String[] args)
	{
		ArrayList al = new ArrayList();
		int[] arr = new int[10]; //标明长度
		for(int i=0;i<arr.length;i++)
		{
			arr[i] = (int)(Math.random()*100+1);
		}
		for(int i=0;i<arr.length;i++)
		{
			if(arr[i]>=10)
				al.add(arr[i]);
		}
		Iterator it = al.iterator();
		while(it.hasNext())
		{
			System.out.println(it.next());
		}
	}
}

练习二:Collection集合练习

一、定义一个方法listTest(ArrayList al, Integer s),要求返回s在al里面第一次出现的索引,如果s没出现过返回-1。

import java.util.*;
class Test
{
	//定义一个方法listTest(ArrayList<Integer> al, Integer s),
	//要求返回s在al里面第一次出现的索引,如果s没出现过返回-1。
	static int listTest(ArrayList<Integer> al, Integer s)
	{
		return al.indexOf(s);
	}
	public static void main(String[] args)
	{
		ArrayList<Integer> al = new ArrayList<Integer>();
		al.add(1);
		al.add(2);
		al.add(4);
		al.add(3);
		al.add(5);
		System.out.println(Test.listTest(al,3));
	}
}

已知数组存放一批QQ号码,QQ号码最长为11位,最短为5位String[] strs = {“12345”,“67891”,“12347809933”,“98765432102”,“67891”,“12347809933”}。
将该数组里面的所有qq号都存放在LinkedList中,将list中重复元素删除,将list中所有元素分别用迭代器和增强for循环打印出来。

import java.util.*;
class Test
{
	public static void main(String[] args)
	{
		//方法一:
		String[] strs = {"12345","67891","12347809933","98765432102","67891","12347809933"};
		LinkedList<String> al = new LinkedList<String>();
		for(int i=0;i<strs.length;i++)
		{
			al.add(strs[i]);
		}
		for(int j=0;j<al.size();j++)
		{
			for(int k=j+1;k<al.size();k++)
			{
				if(al.get(j).equals(al.get(k)))
				{
					al.remove(k);
				}
			}
		}
		Iterator it = al.iterator();
		while(it.hasNext())
		{
			System.out.println(it.next());
		}
		
		//方法二:直接使用Set
		LinkedHashSet<String> al1 = new LinkedHashSet<String>();
		al.add("12345");
		al.add("67891");
		//因为String对象的equals方法就是判别两个字符串是否相同,所以不需重写equals方法
		al.add("12347809933");
		al.add("98765432102");
		al.add("67891");
		al.add("12347809933");
		Iterator it1 = al1.iterator();
		while(it1.hasNext())
		{
			System.out.println(it1.next());
		}
	}
}

练习四:HashSet的使用
双色球规则:双色球每注投注号码由6个红色球号码和1个蓝色球号码组成。红色球号码从1—33中选择;蓝色球号码从1—16中选择;请随机生成一注双色球号码。(要求同色号码不重复)

import java.util.*;
class Test
{
	public static void main(String[] args)
	{
		HashSet<Integer> hs = new HashSet<Integer>();
		int i = 0;
		while(i<6)
		{
			Random rand = new Random();
			int randNum = rand.nextInt(33)+1;
			if(!hs.contains(randNum))
			{
				hs.add(randNum);
				i++;
			}
		}
		boolean flag = true;
		while(flag)
		{
			Random blue = new Random();
			int blueNum = blue.nextInt(16)+1;
			if(!hs.contains(blueNum))
			{
				hs.add(blueNum);
				flag = false;
			}
		}
		Iterator it = hs.iterator();
		while(it.hasNext())
		{
			System.out.println(it.next());
		}
	}
}

练习五:Comparable和Comparator的使用

分别用Comparable和Comparator两个接口对下列四位同学的成绩做降序排序,如果成绩一样,那在成绩排序的基础上按照年龄由小到大排序。
在这里插入图片描述
注意:Comparator不在所要比较的对象的类中实现,而是另外实现创建类实现Comparator中的compare,再在容器中加比较器,而Comparable在所要比较的对象的类中实现compareTo方法。

方法一:使用Comparator

import java.util.*;
class MyCompare implements Comparator<Student>
{
	public int compare(Student s1,Student s2)
	{
		if(s1.getScore()>s2.getScore())
			return 1;
		else if(s1.getScore()<s2.getScore())
			return -1;
		else
		{
			if(s1.getAge()>s2.getAge())
				return 1;
			if(s1.getAge()<s2.getAge())
				return -1;
			return s1.getName().compareTo(s2.getName());
		}
	}
}
class Student
{
	private String name;
	private int age;
	private float score;
	Student(String name,int age,float score)
	{
		this.name = name;
		this.age = age;
		this.score = score;
	}
	public String getName()
	{
		return name;
	}
	public int getAge()
	{
		return age;
	}
	public float getScore()
	{
		return score;
	}
	
}
class Test
{
	public static void main(String[] args)
	{
		TreeSet ts = new TreeSet(new MyCompare());
		ts.add(new Student("liusan",20,90.0F));
		ts.add(new Student("lisi",22,90.0F));
		ts.add(new Student("wangwu",20,90.0F));
		ts.add(new Student("sunliu",22,100.0F));
		Iterator it = ts.iterator();
		while(it.hasNext())
		{
			Student stu = (Student)it.next();
			System.out.println("score="+stu.getScore()+" age="+stu.getAge()+" name="+stu.getName());
		}
	}
}

方法二:使用Comparable

import java.util.*;
class Student implements Comparable<Student>
{
	private String name;
	private int age;
	private float score;
	Student(String name,int age,float score)
	{
		this.name = name;
		this.age = age;
		this.score = score;
	}
	public int compareTo(Student stu)
	{
		if(this.age>stu.age)
			return 1;
		else if(this.age < stu.age)
			return -1;
		else
		{
			return this.getName().compareTo(stu.getName());
		}
	}

	public String getName()
	{
		return name;
	}
	public int getAge()
	{
		return age;
	}
	public float getScore()
	{
		return score;
	}
}
class Test
{
	public static void main(String[] args)
	{
		TreeSet ts = new TreeSet();
		ts.add(new Student("liusan",20,90.0F));
		ts.add(new Student("lisi",22,90.0F));
		ts.add(new Student("wangwu",20,90.0F));
		ts.add(new Student("sunliu",22,100.0F));
		Iterator it = ts.iterator();
		while(it.hasNext())
		{
			Student stu = (Student)it.next();
			System.out.println("score="+stu.getScore()+" age="+stu.getAge()+" name="+stu.getName());
		}
	}
}

练习六:Map集合的使用(一)

一、现在有一个map集合如下:

Map<Integer,String> map = new HashMap<Integer, String>();
map.put(1, “张三丰”);
map.put(2, “周芷若”);
map.put(3, “汪峰”);
map.put(4, “灭绝师太”);

要求:

1.遍历集合,并将序号与对应人名打印。

2.向该map集合中插入一个编码为5姓名为李晓红的信息

3.移除该map中的编号为1的信息

4.将map集合中编号为2的姓名信息修改为"周林"

Map遍历方式一:通过keySet获取全部的键的Set集合。
class Test
{
	public static void main(String[] args)
	{
		Map<Integer,String> map = new HashMap<Integer,String>();
		map.put(1, "张三丰");
      map.put(2, "周芷若");
      map.put(3, "汪峰");
      map.put(4, "灭绝师太");
      map.put(5, "李晓红");
      map.put(2,"周林");   //因为map键是唯一的,所以放入相同键,相当于覆盖
      map.remove(1);
      //map.
      Set<Integer> keyset = map.keySet();
      Iterator it = keyset.iterator();
      while(it.hasNext())
      {
      	Integer integer = (Integer)it.next();
      	System.out.println("key:"+integer+" value:"+map.get(integer));
      }
	}
}
Map遍历方式二:通过entrySet()获取关系
class Test
{
	public static void main(String[] args)
	{
		Map<Integer,String> map = new HashMap<Integer,String>();
  		map.put(1, "张三丰");
        map.put(2, "周芷若");
        map.put(3, "汪峰");
        map.put(4, "灭绝师太");
        map.put(5, "李晓红");
        map.remove(1);
        map.put(2,"周林");   //因为map键是唯一的,所以放入相同键,相当于覆盖
        Set<Map.Entry<Integer, String>> keyset = map.entrySet();  //获取键值对之间关系,关系是Map.Entry的
        Iterator<Map.Entry<Integer, String>> it = keyset.iterator(); //迭代器迭代,迭代器里面放的是关系
        while(it.hasNext())
        {
        	Map.Entry<Integer, String> map_entry = it.next(); //取出关系
        	Integer key = map_entry.getKey();
        	String value = map_entry.getValue();
        	System.out.println("key:"+key+" value:"+value);
        }   
	}
}
练习七:Map集合的使用(二)

一、有2个数组,第一个数组内容为:[黑龙江省,浙江省,江西省,广东省,福建省],第二个数组为:[哈尔滨,杭州,南昌,广州,福州],将第一个数组元素作为key,第二个数组元素作为value存储到Map集合中。如{黑龙江省=哈尔滨, 浙江省=杭州, …}。

import java.util.*;
class Test
{
	public static void main(String[] args)
	{
		Map<String,String> map = new HashMap<String,String>();
		String[] char_str1 = {"黑龙江省","浙江省","江西省","广东省","福建省"};
		String[] char_str2 = {"哈尔滨","杭州","南昌","广州","福州"};
		for(int i = 0;i<char_str1.length;i++)
		{
			map.put(char_str1[i], char_str2[i]);
		}
		
		//遍历方式一
		Set<Map.Entry<String,String>> entry = map.entrySet();
		Iterator<Map.Entry<String,String>> it1 = entry.iterator();
		while(it1.hasNext())
		{
			Map.Entry<String,String> ss1 = it1.next();
			System.out.println("key:"+ss1.getKey()+" value:"+ss1.getValue());
		}
		
		//遍历方式二
		Set<String> ss = map.keySet();
		Iterator it = ss.iterator();
		while(it.hasNext())
		{
			String ss2 = (String)it.next();
			System.out.println("key:"+ss2+" value:"+map.get(ss2));
		}      
	}
}

练习八:Map集合的使用(三)

一、定义一个泛型为String类型的List集合,统计该集合中每个字符(注意,不是字符串)出现的次数。例如:集合中有”abc”、”bcd”两个元素,程序最终输出结果为:“a = 1,b = 2,c = 2,d = 1”。

import java.util.*;
class Test
{
	public static void main(String[] args)
	{
		List<String> ls = new ArrayList<String>();
		ls.add("abcd");
		ls.add("adebc");
		ls.add("sffa");
		Iterator it = ls.iterator();
		String ss = "";
		while(it.hasNext())
		{
			 ss += (String)it.next();
		}
		getEachStrNum(ss);
	}
	public static void getEachStrNum(String str)
	{
		Map<Character,Integer> map = new HashMap<Character,Integer>();
		for(int i = 0;i<str.length();i++)
		{
			char s = str.charAt(i);
			if(map.containsKey(s))
			{
				int num = map.get(s);
				map.put(s,num+1);
			}
			else
			{
				map.put(s, 1);
			}
		}
		 Set<Map.Entry<Character,Integer>> charSet = map.entrySet(); 
		 Iterator it = charSet.iterator();
		 while(it.hasNext())
		 {
			 Map.Entry<Character,Integer> entry = (Map.Entry<Character,Integer>)it.next();
			 System.out.print(entry.getKey()+" = "+ entry.getValue()+" ");
		 }
	}
}

练习九:Map集合的使用(四)
一、利用Map,完成下面的功能:

从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队。如果该 年没有举办世界杯,则输出:没有举办世界杯。

//tips:参阅Map接口containsKey(Object key)方法

二、在原有世界杯Map 的基础上,增加如下功能: 读入一支球队的名字,输出该球队夺冠的年份列表。 例如,读入“巴西”,应当输出 1958 1962 1970 1994 2002 读入“荷兰”,应当输出 没有获得过世界杯

//tips:参阅Map接口containsValue(Object value)方法

示例:
在这里插入图片描述

import java.util.*;
//这种一一对应的一定要想到Map

//定义一个泛型为String类型的List集合,统计该集合中每个字符(注意,不是字符串)出现的次数。
//例如:集合中有”abc”、”bcd”两个元素,
//程序最终输出结果为:“a = 1,b = 2,c = 2,d = 1”。
class Test
{
	public static void main(String[] args)
	{
		HashMap<Integer,String> map = new HashMap<Integer,String>();
		map.put(1930,"乌拉圭");
        map.put(1934,"意大利");
        map.put(1938,"意大利");
        map.put(1950,"乌拉圭");
        map.put(1954,"西德");
        map.put(1958,"巴西");
        map.put(1962,"巴西");
        map.put(1966,"英格兰");
        map.put(1970,"巴西");
        map.put(1974,"西德");
        map.put(1978,"阿根廷");
        map.put(1982,"意大利");
        map.put(1986,"阿根廷");
        map.put(1990,"西德");
        map.put(1994,"巴西");
        map.put(1998,"法国");
        map.put(2002,"巴西");
        map.put(2006,"意大利");
        map.put(2010,"西班牙");
        map.put(2014,"德国");
        System.out.println("请输入年份:");
        Scanner sc = new Scanner(System.in);
        int inputNum = sc.nextInt();
        Set<Map.Entry<Integer,String>>  set = map.entrySet();
        Iterator it = set.iterator();
        while(it.hasNext())
        {
        	Map.Entry<Integer,String> entry = (Map.Entry<Integer,String>)it.next();
        	if(entry.getKey()==inputNum)
        	{
        		System.out.println(entry.getKey()+"年获得世界杯冠军的是:"+entry.getValue());
        	}
        }
        String temp = sc.nextLine();
        System.out.println("请输入国家名称");
        String inputStr = sc.nextLine();
       // Set<Map.Entry<Integer,String>>  set1 = map.entrySet();
        Iterator it1 = set.iterator();
        System.out.print("获得冠军的年份有:");
        int flag = 0;
        while(it1.hasNext())
        {
        	Map.Entry<Integer,String> entry1 = (Map.Entry<Integer,String>)it1.next();
        	if(entry1.getValue().equals(inputStr))
        	{
        		System.out.print(entry1.getKey()+" ");
        		flag++;
        	}
        }
        if(flag==0)
        {
        	System.out.println("没有获得过世界杯");
        }
	}
}

练习十:综合练习

1.站编号和站名对应关系如下:

        1=朱辛庄

        2=育知路

        3=平西府

        4=回龙观东大街

        5=霍营

   //....

将以上对应关系的数据存储到map集合中,key:表示站编号,value:表示站名,并遍历打印(可以不按顺序打印):

   第10站: 森林公园南门

   第6站: 育新

   第12站: 奥体中心

   第13站: 北土城

   //...

2.计算地铁票价规则:

   总行程 3站内(包含3站)收费3元,

        3站以上但不超过5站(包含5站)的收费4元,

        5站以上的,在4元的基础上,每多1站增加2元,

        10元封顶;

3.打印格式(需要对键盘录入的上车站和到达站进行判断,如果没有该站,提示重新输入,直到站名存在为止):

   注意:每站需要2分钟

   请输入上车站:

   沙河

   您输入的上车站:沙河不存在,请重新输入上车站:

   上地

   您输入的上车站:上地不存在,请重新输入上车站:

   朱辛庄

   请输入到达站:

   沙河

   您输入的到达站:沙河不存在,请重新输入到达站:

   西二旗

   您输入的到达站:西二旗不存在,请重新输入到达站:

   西小口

   从朱辛庄到西小口共经过6站收费6元,大约需要 12分钟
import java.util.*;

class Test
{
	public static void main(String[] args)
	{
		HashMap<Integer,String> map = new HashMap<Integer,String>();
		map.put(1, "朱辛庄");
        map.put(2, "育知路");
        map.put(3, "平西府");
        map.put(4, "回龙观东大街");
        map.put(5, "霍营");
        map.put(6, "育新");
        map.put(7, "西小口");
        map.put(8, "永泰庄");
        map.put(9, "林萃桥");
        map.put(10, "森林公园南门");
        map.put(11, "奥林匹克公园");
        map.put(12, "奥体中心");
        map.put(13, "北土城");
        String upStation="";
        String downStation="";
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入上车的车站:");
        boolean flag = true;
        Set<Map.Entry<Integer, String>> entry = map.entrySet();
        upStation = sc.nextLine();
        int upNum=0;
		int downNum=0;
        while(flag)
        {
        	Iterator it = entry.iterator();
        	while(it.hasNext())
        	{
        		
        		Map.Entry<Integer, String> map_entry =(Map.Entry<Integer, String>)it.next();
        		//System.out.println(map_entry.getKey()+" "+map_entry.getValue());
        		if(map_entry.getValue().equals(upStation))
        		{
        			//System.out.println(map_entry.getKey()+" "+map_entry.getValue());
        			upNum = map_entry.getKey();
        			flag = false;
        		}
        	}
        	if(flag == true)
        	{
        		System.out.println("请重新输入:");
        		upStation = sc.nextLine();
        	}
        }
        System.out.println("请输入下车的车站:");
        boolean flag1 = true;
        downStation = sc.nextLine();
        while(flag1)
        {
        	Iterator it = entry.iterator();
        	while(it.hasNext())
        	{
        		Map.Entry<Integer, String> map_entry =(Map.Entry<Integer, String>)it.next();
        		if(map_entry.getValue().equals(downStation))
        		{
        			downNum = map_entry.getKey();
        			flag1 = false;
        		}
        	}
        	if(flag1 == true)
        	{
        		System.out.println("请重新输入");
        		downStation = sc.nextLine();
        	}
        }
    	if(downNum-upNum<=3)
    	{
    		System.out.println("从"+upStation+"到"+downStation+"收费"+3);
    	}
    	else if(downNum-upNum>3 & downNum-upNum<=5)
    	{
    		System.out.println("从"+upStation+"到"+downStation+"收费"+4);
    	}
    	else if (downNum-upNum>5 & downNum-upNum<=9)
        {
            int prize=(downNum-upNum-5)*2+4;
            if (prize>=10)
                prize=10;
            System.out.println("从"+upStation+"到"+downStation+"收费"+prize);
        }
    	else
    		System.out.println("从"+upStation+"到"+downStation+"收费"+10);  
	}
}
;