计算机科学中,数据结构(英語:data structure)是计算机中存储、组织数据的方式[1]

二叉树是数据结构的一种类型

数据结构意味着介面封装:一个数据结构可被视为两个函数之间的介面,或者是由数据类型联合组成的存储内容的访问方法封装。

大多数数据结构都由数列记录可辨识联合引用等基本类型构成。举例而言,可為空的引用(nullable reference)是引用与可辨识联合的结合体,而最简单的链式结构链表则是由记录与可空引用构成。

数据结构可透过编程语言所提供的数据类型引用及其他操作加以实现。一个设计良好的数据结构,应该在尽可能使用较少的时间与空间资源的前提下,支援各種程式執行。[2]

不同种类的数据结构适合不同种类的应用,部分資料結構甚至是為了解決特定問題而設計出來的。例如B树即為加快樹狀結構存取速度而設計的資料結構,常被應用在資料庫和檔案系統上。

正確的数据结构選擇可以提高演算法的效率(請參考演算法效率)。在電腦程式设计的過程中,选择适当的数据结构是一項重要工作。许多大型系统的編寫经验顯示,程式設計的困难程度与最终成果的质量与表现,取决于是否选择了最適合的数据结构。

系統架構的关键因素是数据结构而非算法的見解,导致了多种形式化的设计方法与编程语言的出现。绝大多数的语言都带有某种程度上的模块化思想,透过将数据结构的具体实现封装隐藏于使用者介面之后的方法,来让不同的应用程序能够安全地重用这些数据结构。C++JavaPython面向对象的编程语言可使用来達到這個目的。

因为数据结构概念的普及,现代编程语言及其API中都包含了多种預設的数据结构,例如C++标准模板库中的容器、Java集合框架以及微软的.NET Framework

常见的数据结构

编辑

参考文献

编辑
  1. ^ 谢柏青; 余晓歌. 算法与数据结构. 2001年. ISBN 7-04-009446-0. 
  2. ^ 杰伊·温格罗; 袁志鹏译. 数据结构与算法图解. 人民邮电出版社. : 1–174. ISBN 9787115509000. 

外部链接

编辑

📚 Artikel Terkait di Wikipedia

容器 (数据类型)

Java ConcurrentMap Paul E. Black (ed.), entry for data structure in Dictionary of Algorithms and Data Structures. US National Institute of Standards and

共递归

nodes in a data structure, then removing the nodes in the data structure in turn and iterating over its children. If the data structure is a stack (LIFO)

数据结构术语列表

Unrolled linked list(英语:Unrolled linked list) VList 异或链表 Zipper(英语:Zipper (data structure)) Doubly connected edge list(英语:Doubly connected edge list) Difference

Pandas

datasets in Python. [2023-09-28]. (原始内容存档于2023-08-24).  Internal Structure of Pandas DataFrames. [2023-12-25]. (原始内容存档于2023-12-25).  NumPy glossary.  Source

尾调用

ret; } 在这里,a(data) 处于 foo2 的尾位置,但不处于 foo1 或 foo3 的尾位置。这是因為程序必須返回這2個 a 函數的调用以檢查、更動 a 的返回值。 传统模式的编译器对于尾调用的处理方式就像处理其他普通函数调用一样,总会在调用时创建一个新的栈帧(stack frame)并将其推入调用栈顶部,用于表示该次函数调用。

Scheme

stack implementations of LISP such as MacLISP). Second, the upward funarg problem(英语:funarg problem) [Moses] requires that the environment structure be

数据结构对齐

current alignment to stack */ #pragma pack(1) /* set alignment to 1 byte boundary */ struct MyPackedData { char Data1; long Data2; char Data3; }; #pragma pack(pop)

克里斯·拉特納

拉特納及他的團隊,為了蘋果電腦開發應用程式系統。克里斯一開始將LLVM运行时的编译架構在OpenGL stack之上,这样OpenGL stack可以产出更高效率的图形代码。OpenGL stack成為JIT compiler, Xcode 3.1實現了llvm-gcc compiler, Xcode