集合简单总结

集合简单总结

顶层接口:

Collection,他里面的方法,子接口及其实现类都能使用

List接口:

有序、有下标、元素可重复

实现类:
	ArrayList:     底层数组实现,查询快、增删慢、线程不安全、效率高
	Vector:        底层数组实现,查询快、增删慢、线程安全、效率低
	LinkedList:   	底层链表实现,查询慢、增删快、线程不安全、效率高
Set接口:

无序、无下标、元素不可重复

实现类:
	HashSet:线程不安全,底层是HashMap结构,key就是要存的set元素,而value则是统一默认为Object对象,key不能重复,因此set不能重复
	TreeSet: 底层是TreeMap实现,自动排序,实现了Comparable接口,覆写其中的comparaTo方法
Map接口:
实现类:
	HashMap:线程不安全、效率高、允许key或value为null
			底层通过数组加链表形式实现,即创建一个默认长度为16的table或entry数组,每一个数组元素上都可以通过链表形式接着存储节点元素,(hash,key,value,next)
			过程:	存值过程:比如存储(key,value):(10,“haha”)的一个A节点,首先得到key值10的hashcode,通过散列算法(最简单的是取余算法)来得到hash值(比如3),通过该值作为下标找到table中存储位置,将A节点存进去,如果该位置已经有了节点,那就通过链表形式存在该节点的后面,即next指向A节点
		   			取值过程:也是通过key值得到hash,找到相应table中的元素位置,然后通过equals比较该位置上的链表上的所有key值,找到key相等的那个节点,然后将其value值返回即可
	HashTable:线程安全、效率低、不允许key或value为null	
	TreeMap:可自动排序(根据key递增排序),也可以自定义一个类,通过类对象中的属性来自定义排序,需要实现Comparable接口,覆写其中的comparaTo方法,在该方法中指定想要通过对象的哪个属性进行排序,返回:负数:小于,0:等于,正数:大于
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
集合是离散数学中的重要概念,它是由一些互异的元素组成的整体。在实际应用中,集合的交、并、差等操作是常见的需求。下面是针对集合的运算在 C 语言中的实验总结。 1. 集合的表示:集合可以用数组、链表等数据结构来表示,其中数组是常用的一种方法。可以定义一个布尔类型的数组,数组中的每个元素表示对应下标的元素是否在集合中出现。 2. 集合的初始化:在定义集合数组后,需要对集合数组进行初始化。可以定义一个函数,将集合数组中的所有元素都设置为 false 表示不出现在集合中;也可以定义一个函数,根据用户给定的元素列表,将集合数组中对应元素设置为 true 表示出现在集合中。 3. 集合的交:集合的交可以通过遍历两个集合数组,对应位置上的元素都为 true 时,将结果集合数组中的对应位置也设置为 true。代码示例: ``` void set_intersection(bool set1[], bool set2[], bool result[]) { for (int i = 0; i < SET_SIZE; i++) { if (set1[i] && set2[i]) { result[i] = true; } else { result[i] = false; } } } ``` 4. 集合的并:集合的并可以通过遍历两个集合数组,对应位置上的元素有一个为 true 时,将结果集合数组中的对应位置也设置为 true。代码示例: ``` void set_union(bool set1[], bool set2[], bool result[]) { for (int i = 0; i < SET_SIZE; i++) { if (set1[i] || set2[i]) { result[i] = true; } else { result[i] = false; } } } ``` 5. 集合的差:集合的差可以通过遍历两个集合数组,对应位置上的元素在 set1 中为 true,而在 set2 中为 false 时,将结果集合数组中的对应位置也设置为 true。代码示例: ``` void set_difference(bool set1[], bool set2[], bool result[]) { for (int i = 0; i < SET_SIZE; i++) { if (set1[i] && !set2[i]) { result[i] = true; } else { result[i] = false; } } } ``` 6. 集合的输出:可以定义一个函数,遍历集合数组,将数组中元素为 true 的下标输出。代码示例: ``` void set_print(bool set[]) { printf("{ "); for (int i = 0; i < SET_SIZE; i++) { if (set[i]) { printf("%d ", i); } } printf("}\n"); } ``` 以上是集合的交、并、差等运算在 C 语言中实现的简单示例。希望能对你的学习有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值