• 实验四.集合


    一、实验目的

    (1)掌握List集合、Set集合以及Map集合的使用;
    (2)熟悉泛型的使用;
    (3)熟悉Collection和Arrays工具类的使用

    二、预习与准备

    (1)List接口、Set接口和Map接口的使用;
    (2)泛型,预习通过泛型解决不同数据类型转换的问题;
    (3)Collection工具集和Arrays工具集相关方法的使用。

    三、实验内容

    1、(list集合)输入工人信息:
    (1)创建一个List,在List 中增加三个工人,基本信息如下:

    姓名年龄工资
    zhang3183000
    li4253500
    wang5223200

    (2)在li4 之前插入一个工人,信息为:姓名:zhao6,年龄:24,工资3300 。
    (3)删除wang5 的信息 。
    (4)遍历,打印List 中所有工人的信息 。
    参考代码:

    import java.util.ArrayList;
    import java.util.Iterator;
    import java.util.List;
    
    class Worker {
    	String name;
    	int age;
    	int salary;
    
    	public Worker() {
    		super();
    	}
    
    	public Worker(String name, int age, int salary) {
    		super();
    		this.name = name;
    		this.age = age;
    		this.salary = salary;
    	}
    
    	@Override
    	public String toString() {
    		return "Worker [name=" + name + ", age=" + age + ", salary=" + salary + "]";
    	}
    
    }
    
    public class Test1 {
    	public static void main(String[] args) {
    		// 1.创建一个List,在List 中增加三个工人
    		List<Worker> list = new ArrayList<Worker>();
    		list.add(new Worker("zhang3", 18, 3000));
    		list.add(new Worker("li4", 25, 3500));
    		list.add(new Worker("wang5", 22, 3200));
    
    		// 遍历输出
    		System.out.println("1.创建一个List,在List 中增加三个工人后的集合信息为:");
    		Iterator<Worker> iterator1 = list.iterator();
    		while (iterator1.hasNext()) {
    			Worker w = iterator1.next();
    			System.out.println(w.toString());
    		}
    
    		// 2.在li4 之前插入一个工人,信息为:姓名:zhao6,年龄:24,工资3300
    		list.add(1, new Worker("zhao6", 24, 3300));
    		// 遍历输出
    		System.out.println("2.在li4 之前插入一个工人,信息为:姓名:zhao6,年龄:24,工资3300后的集合为:");
    		Iterator<Worker> iterator2 = list.iterator();
    		while (iterator2.hasNext()) {
    			Worker w = iterator2.next();
    			System.out.println(w.toString());
    		}
    
    		// 3.删除wang5 的信息 。
    		list.remove(3);
    
    		// 遍历输出
    		System.out.println("3.删除wang5 的信息 后的集合为:");
    		Iterator<Worker> iterator3 = list.iterator();
    		while (iterator3.hasNext()) {
    			Worker w = iterator3.next();
    			System.out.println(w.toString());
    		}
    
    	}
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67

    运行结果:
    在这里插入图片描述

    2、现有若干图书信息(包含名称title、作者author、定价price)需要存储到set集合中,保证集合中无重复元素,并遍历查看。可以认为所有信息都相同的图书为重复数据。
    参考代码:

    import java.util.HashSet;
    import java.util.Objects;
    import java.util.Set;
    
    class Book {
    	String title;
    	String author;
    	double price;
    
    	public Book() {
    		super();
    	}
    
    	public Book(String title, String author, double price) {
    		super();
    		this.title = title;
    		this.author = author;
    		this.price = price;
    	}
    
    	@Override
    	public String toString() {
    		return "Book [title=" + title + ", author=" + author + ", price=" + price + "]";
    	}
    
    	@Override
    	public boolean equals(Object o) {
    		if (this == o)
    			return true;
    		if (o == null || getClass() != o.getClass())
    			return false;
    		Book book = (Book) o;
    		return Double.compare(book.price, price) == 0 && Objects.equals(title, book.title)
    				&& Objects.equals(author, book.author);
    	}
    
    	@Override
    	public int hashCode() {
    		return Objects.hash(title, author, price);
    	}
    }
    
    public class Test2 {
    	public static void main(String[] args) {
    		Set<Book> set = new HashSet<Book>();
    		// 添加两个完全一样的
    		set.add(new Book("三国演义", "罗贯中", 100));
    		set.add(new Book("三国演义", "罗贯中", 100));
    		// 添加两个只有书名有区别的
    		set.add(new Book("红楼梦", "曹雪芹", 1000));
    		set.add(new Book("红楼梦1", "曹雪芹", 1000));
    
    		// 添加两个只有作者有区别的
    		set.add(new Book("西游记", "吴承恩", 1000));
    		set.add(new Book("西游记", "吴承恩1", 1000));
    
    		// 添加两个只有价格有区别的
    		set.add(new Book("水浒传", "施耐庵", 100));
    		set.add(new Book("水浒传", "施耐庵", 1000));
    		//遍历查看
    		System.out.println("遍历查看:");
    		for (Book book : set){
    			System.out.println(book);
    		}
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66

    运行结果:
    在这里插入图片描述

    3、已知字符串“adhflkalkfdhasdkhflsa”
    (1)统计去掉重复后的字符
    (2)统计每个字符出现的次数,使用map存储,字符为键,次数为值。
    (3)遍历map,打印统计信息
    参考代码:

    import java.util.HashMap;
    import java.util.HashSet;
    import java.util.Iterator;
    import java.util.Map;
    import java.util.Set;
    
    public class Test3 {
    	public static void main(String[] args) {
    		String str="adhflkalkfdhasdkhflsa";
    		System.out.println("字符串为:"+str);
    		Set<Character> set=new HashSet<Character>();
    		char[] ch=str.toCharArray();
    		for(Character c:ch) {
    			set.add(c);
    		}
    		
    		Iterator<Character> li= set.iterator();
    		System.out.print("去掉重复后的字符:");
            while(li.hasNext()){
            	Character character=li.next();
                System.out.print(character+" ");
            }
            System.out.println("\n去掉重复后共有"+set.size()+"个字符。");
            
            Map<Character,Integer> map=new HashMap<Character,Integer>();
        	for(Character c: ch) {
        		map.put(c, map.containsKey(c)?(map.get(c)+1):1);
        	}
        	
        	//遍历map,打印统计信息
        	System.out.println("遍历map,打印统计信息:");
        	Set keyset=map.keySet();
        	Iterator iterator = keyset.iterator();
            while(iterator.hasNext()){
            	Character key=(Character) iterator.next();
            	int count=map.get(key);
                System.out.println(key+":"+count);
            }
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40

    运行结果:
    在这里插入图片描述

    四、实验小结

    通过本次实验更加熟悉了List集合、Set集合以及Map集合的使用,集合之间的关系更加明了,根据需要使用合适的集合,才能使逻辑更加简单,同时熟悉了泛型在集合中的使用,可以解决不同数据类型之间的转化。Arrays工具类可以使集合转化为数组,map集合是一个键值对,可根据键从集合中取出相应的值。在遍历输出中,在循环遍历中有for循环和foreach以及迭代器Iterator,在遍历集合时,根据不同场景选择不同的遍历方式,会更加方便。

  • 相关阅读:
    java操作数据库的工具类简介说明
    数学推理题:张王李赵陈五对夫妇聚会,见面握手
    MySQL数据库、表的基本操作和常用数据类型
    postgres创建外部表
    Spring Boot 接口一个 JSON 字符串用两个对象去接收,这能行吗?
    R语言dplyr包select函数筛选dataframe数据中以指定字符串开头的数据列(变量)
    【支持M1】MacDroid for Mac:Mac和Android安卓设备数据互通
    用于车载T-BOX汽车级的RA8900CE
    05.SpringCloudAlibaba-注册中心Nacos
    redis set命令总结
  • 原文地址:https://blog.csdn.net/weixin_46220576/article/details/127587945