集合 (计算机科学)

✍ dations ◷ 2025-06-08 10:55:33 #数据结构,抽象数据类型

在计算机科学中,集合是一组可变量量的数据项(也可能是0个)的组合,这些数据项可能共享某些特征,需要以某种操作方式一起进行操作。一般来讲,这些数据项的类型是相同的,或基类相同(若使用的语言支持继承)。列表(或数组)通常不被认为是集合,因为其大小固定,但事实上它常常在实现中作为某些形式的集合使用。

集合的种类包括列表,集,多重集,树和图。枚举类型可以是列表或集。

在列表中,数据项的顺序是确定的,也可以存在多个相同的数据项。列表支持的操作包括查找项目并找到其位置(若存在),将项目从列表中删除,在特定位置插入项目等。通常的队列,或称FIFO即是一个列表,该列表只能在一端添加项目,而在另一端删除项目。而栈,或LIFO则只能在同一端添加或删除项目。不管是队列还是栈,集合中项目的顺序都应当是一定的,因此这两种情况只是列表的特例。其它列表支持的操作包括排序,再一次说明了其中顺序的重要性。

列表的具体形式包括数组,链表等。

与列表不同,在集中,数据项是无序的,也不允许存在相同数据项。集支持添加、删除和查找项目。一些语言内建对集的支持,而在其它语言中,可以利用散列表实现集。

多重集的行为类似于集,其中数据项是无序的。但在多重集中,可以存在相同的数据项。多重集支持的操作包括添加、删除项,查询相同项在多重集中出现的次数。多重集可以通过排序转换成列表。

关联数组(或称查找表,字典等)的行为和字典相似,为键(例如字典中的单词)输入提供一个值(如字典中的定义)输出。值可以是对复杂数据结构的引用。通常使用散列表实现高效率的关联数组。

在树中,“根”节点与一定数量的数据项以亲-子关系联系起来,而其子数据项也与另外的数据项以同样的方式联系。除了根节点的每个项都有且只有一个父节点,并可能有一些子节点。树支持的操作包括遍历,插入等。用于排序操作的树通常称为堆。通常使用树来保存存在包含亲-子关系的数据,例如菜单,目录及其中文件等。

在图中,每个数据项都可以与一个或多个其它数据项联系起来,其中每个节点都是平等的,类似于无根节点、无亲-子关系的树。图支持的操作包括遍历,查找等。图常常用于对实际问题进行建模,并解决这些问题。在生成树协议中,创建一张代表网络结构的图(或称网格),从而了解应当断开哪些链路以避免数据回圈。

如上所述,集合,以及集合的各种分类都只是抽象概念。由于名字相同或相似,集合及其在各种语言中的实现常常会造成文字上的混淆。集合,列表,集,树等名字究竟是数据结构,抽象数据类型抑或类只能通过具体分析来确定。其中,集合则是计算问题的解决方案中抽象程度最高的概念。从这个方面来看,若过于关注其实现,则可能会对理解集合的数学概念产生反作用。

相关

  • 卡尔加里大学© 卡尔加里大学校徽卡尔加里大学(University of Calgary)位于加拿大艾伯塔省卡尔加里的西北部,是加拿大前排名前七的研究性大学之一。它的前身是阿尔伯塔大学卡尔加里分校。19
  • 三B大力神三B是自大力神二号洲际弹道导弹及大力神三号运载火箭改良后之火箭总称,加上Agena上面级加以改良,由四枚分散的火箭组成,大力神23B用大力神二号为基础,加上Agena上面级;而大
  • 迪拜国际机场迪拜国际机场(阿拉伯语:مطار دبي الدولي‎,IATA代码:DXB;ICAO代码:OMDB)是阿拉伯联合酋长国迪拜的主要机场,为阿联酋航空的枢纽港。可起降目前所有的机型,是中东地区重
  • 软骨溶解软骨溶解或软骨溶解症(英语:Chondrolysis),又称急性软骨坏死(英语:Acute cartilage necrosis),是指一种软骨裂解的疾病,表现为股骨头(英语:Femoral head)软骨的急性破坏。它可以是股骨骨
  • 特伦甘纳共产党特伦甘纳共产党(英语:Telangana Communist Party)是印度特伦甘纳邦的一个共产主义政党。该党的领袖是S. Venkat Swamy。该党曾长期致力于将特伦甘纳地区从安得拉邦分离出来,使之
  • 席摩·海赫席摩·海赫(芬兰语:Simo Häyhä,1905年12月17日-2002年4月1日)是一位已故芬兰陆军狙击手,被苏联部队称为“白色死神”(俄语:Белая Смерть;芬兰语:Valkoinen kuolema)。原本
  • 番樱桃属番樱桃属(学名:)是桃金娘科下的一个属,为常绿乔木或灌木植物。该属共有约1000种,分布于热带地区。
  • 上帝保佑拉脱维亚《上帝保祐拉脱维亚》(拉脱维亚语:Dievs, svētī Latviju!)是拉脱维亚的国歌。作曲人及作词人皆为卡尔利斯·包马尼斯(Kārlis Baumanis,1834年–1904年)。歌曲及歌词由卡尔利斯
  • 大苏山大苏山地理坐标位于河南省信阳市光山县西南22公里,东经113°54′30″—113°59′40″,北纬31°50′13″- 31°53′02″,于2015年1月被中国林业局正式批准设立为“大苏山国家森
  • 大卫·奥利夫大卫·伊恩·奥利夫 CBE FRS FLSW(英语:Learned Society of Wales)(英语:David Ian Olive,/ˈɒlɪv/,1937年4月16日-2012年11月7日),英国理论物理学家,对弦理论和对偶理论做出了基础性