java-list-集合实验

主函数 

package createCode;
public class Main {
	public static void main(String[] args) {
		lt.test();
	}
}

测试类

package createCode;

import java.util.ArrayList;
import java.util.List;

public class ListTest {
    private int start1=0;
    private int end1=7;
    private int start2=3;
    private int end2=10;
    public void test(){
	List<Integer> ls1 = new ArrayList<Integer>();
	for(int i=start1;i<end1;i++){
	    ls1.add(i);
	}
	List<Integer> ls2 = new ArrayList<Integer>();
	for(int i=start2;i<end2;i++){
	    ls2.add(i);
	}
	System.out.println("ls1:"+ls1);
	System.out.println("ls2:"+ls2);
	binjiTest();
	binjiTest2();
	jiaojiTest();
	chajiTest();
	
    }
    /**
     * 并集实验
     */
    public void binjiTest(){
	List<Integer> ls1 = new ArrayList<Integer>();
	for(int i=start1;i<end1;i++){
	    ls1.add(i);
	}
	List<Integer> ls2 = new ArrayList<Integer>();
	for(int i=start2;i<end2;i++){
	    ls2.add(i);
	}
	ls2.addAll(ls1);
	System.out.println("并集:"+ls2);
    }
    /**
     * 并集实验(消除重复)
     */
    public void binjiTest2(){
	List<Integer> ls1 = new ArrayList<Integer>();
	for(int i=start1;i<end1;i++){
	    ls1.add(i);
	}
	List<Integer> ls2 = new ArrayList<Integer>();
	for(int i=start2;i<end2;i++){
	    ls2.add(i);
	}
	ls2.removeAll(ls1);
	ls2.addAll(ls1);
	System.out.println("并集:"+ls2);
    }
    /**
     * 交集实验
     */
    public void jiaojiTest(){
	List<Integer> ls1 = new ArrayList<Integer>();
	for(int i=start1;i<end1;i++){
	    ls1.add(i);
	}
	List<Integer> ls2 = new ArrayList<Integer>();
	for(int i=start2;i<end2;i++){
	    ls2.add(i);
	}
	ls2.retainAll(ls1);
	System.out.println("交集:"+ls2);
    }
    /**
     * 差集实验
     */
    public void chajiTest(){
	List<Integer> ls1 = new ArrayList<Integer>();
	for(int i=start1;i<end1;i++){
	    ls1.add(i);
	}
	List<Integer> ls2 = new ArrayList<Integer>();
	for(int i=start2;i<end2;i++){
	    ls2.add(i);
	}
	ls2.removeAll(ls1);
	System.out.println("差集:"+ls2);
    }
   
}

运行效果

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayList、LinkedList、Vector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 二、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet中。 姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其中计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象的姓名,id:Person对象的身份证号) 主方法中作如下测试: 1)创建一个可放置Person类对象的HashSet; 2)依次添加上述5个对象到HashSet中; 3)把集合中的元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合中添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合中的每个元素的位置与内容; 4)打印集合的大小,然后删除集合中的第3个元素,并显示删除元素的内容,然后再打印目前集合中第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合的基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合中添加5个"键-值"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合中的每个元素的键与值; 4)打印集合的大小,然后删除集合中的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合中的List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?
Java 集合框架是 Java 提供的一组接口和类,用于存储和操作对象的集合Java 集合框架提供了许多集合类,包括 List、Set、Map 等,这些集合类可以存储不同类型的对象,如整数、字符串、自定义对象等。 泛型是 Java 中的一个重要特性,它可以让我们编写更加可读性好、类型安全的代码。泛型允许我们在编译时指定集合中存储的元素类型,并检查代码是否符合类型安全原则。 下面是一个简单的 Java 集合和泛型的示例代码: ```java import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class CollectionDemo { public static void main(String[] args) { // 创建一个 List 集合,并添加元素 List<String> list = new ArrayList<>(); list.add("apple"); list.add("banana"); list.add("orange"); // 遍历 List 集合 for (String fruit : list) { System.out.println(fruit); } // 创建一个 Map 集合,并添加键值对 Map<String, Integer> map = new HashMap<>(); map.put("apple", 1); map.put("banana", 2); map.put("orange", 3); // 遍历 Map 集合 for (Map.Entry<String, Integer> entry : map.entrySet()) { System.out.println(entry.getKey() + ":" + entry.getValue()); } } } ``` 在上面的代码中,我们创建了一个 List 集合和一个 Map 集合,并使用泛型指定集合中存储的元素类型。然后我们使用 add 方法向 List 集合中添加元素,使用 put 方法向 Map 集合中添加键值对。最后,我们使用 for 循环遍历集合,并输出集合中的元素和键值对。 使用 Java 集合和泛型可以让我们更加方便地存储和操作数据,同时也可以让代码更加易读易维护。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值