Você está na página 1de 3

Data structure

keys

hash
function

data structures are based on storing addresses of data


items within the structure itself. Many data structures use
both principles, sometimes combined in non-trivial ways
(as in XOR linking).

buckets
00

John Smith
Lisa Smith
Sandra Dee

01

521-8976

02

521-1234

The implementation of a data structure usually requires


writing a set of procedures that create and manipulate instances of that structure. The eciency of a data structure cannot be analyzed separately from those operations.
This observation motivates the theoretical concept of an
abstract data type, a data structure that is dened indirectly by the operations that may be performed on it, and
the mathematical properties of those operations (including their space and time cost).

03
:

13
14

521-9655

15

A hash table

In computer science, a data structure is a particular 2 Examples


way of organizing data in a computer so that it can be
used eciently.[1][2] Data structures can implement one Main article: List of data structures
or more particular abstract data types(ADT), which are
the means of specifying the contract of operations and
There are numerous types of data structures, generally
their complexity. In comparison, a data structure is a
built upon simpler primitive data types:
concrete implementation of the contract provided by an
ADT.
An array (also called list) is a number of elements
Dierent kinds of data structures are suited to dierent
in a specic order, typically all of the same type. Elkinds of applications, and some are highly specialized to
ements are accessed using an integer index to specspecic tasks. For example, databases use B-tree indexes
ify which element is required (although the elements
for small percentages of data retrieval and compilers and
may be of almost any type). Typical implementadatabases use dynamic hash tables as look up tables.
tions allocate contiguous memory words for the elements of arrays (but this is not always a necessity).
Data structures provide a means to manage large amounts
Arrays may be xed-length or resizable.
of data eciently for uses such as large databases and
internet indexing services. Usually, ecient data struc An associative array (also called a dictionary, map
tures are key to designing ecient algorithms. Some foror object) is a more exible variation on an array, in
mal design methods and programming languages emphawhich name-value pairs can be added and deleted
size data structures, rather than algorithms, as the key orfreely. A hash table is a common implementation of
ganizing factor in software design. Storing and retrieving
an associative array.
can be carried out on data stored in both main memory
and in secondary memory.
A record (also called a tuple or struct) is an aggregate
data structure. A record is a value that contains other
values, typically in xed number and sequence and
typically indexed by names. The elements of records
1 Overview
are usually called elds or members.
A union type species which of a number of permitted primitive types may be stored in its instances,
e.g. oat or long integer. Contrast with a record,
which could be dened to contain a oat and an integer; whereas in a union, there is only one value
at a time. Enough space is allocated to contain the
widest member datatype.

Data structures are generally based on the ability of a


computer to fetch and store data at any place in its memory, specied by a pointer a bit string, representing a
memory address, that can be itself stored in memory and
manipulated by the program. Thus, the array and record
data structures are based on computing the addresses of
data items with arithmetic operations; while the linked
1

7
A tagged union (also called a variant, variant record,
discriminated union, or disjoint union) contains an
additional eld indicating its current type, for enhanced type safety.

Concurrent data structure

A set is an abstract data structure that can store specic values, in no particular order and with no duplicate values.

Linked data structure

Graphs and trees are linked abstract data structures


composed of nodes. Each node contains a value and
one or more pointers to other nodes arranged in a hierarchy. Graphs can be used to represent networks,
while variants of trees can be used for sorting and
searching, having their nodes arranged in some relative order based on their values.

Persistent data structure

An object contains data elds, like a record, as well


as various methods which operate on the contents
of the record. In the context of object-oriented
programming, records are known as plain old data
structures to distinguish them from objects.

Language support

Most assembly languages and some low-level languages,


such as BCPL (Basic Combined Programming Language), lack built-in support for data structures. On the
other hand, many high-level programming languages and
some higher-level assembly languages, such as MASM,
have special syntax or other built-in support for certain data structures, such as records and arrays. For
example, the C and Pascal languages support structs
and records, respectively, in addition to vectors (onedimensional arrays) and multi-dimensional arrays.[3][4]
Most programming languages feature some sort of library
mechanism that allows data structure implementations to
be reused by dierent programs. Modern languages usually come with standard libraries that implement the most
common data structures. Examples are the C++ Standard
Template Library, the Java Collections Framework, and
Microsoft's .NET Framework.
Modern languages also generally support modular programming, the separation between the interface of a library module and its implementation. Some provide
opaque data types that allow clients to hide implementation details. Object-oriented programming languages,
such as C++, Java and Smalltalk may use classes for this
purpose.
Many known data structures have concurrent versions that
allow multiple computing threads to access the data structure simultaneously.

See also
Abstract data type

EXTERNAL LINKS

Data model
Dynamization

List of data structures

Plain old data structure

5 References
[1] Paul E. Black (ed.), entry for data structure in Dictionary
of Algorithms and Data Structures. U.S. National Institute
of Standards and Technology. 15 December 2004. Online
version Accessed May 21, 2009.
[2] Entry data structure in the Encyclopdia Britannica
(2009) Online entry accessed on May 21, 2009.
[3] The GNU C Manual. Free Software Foundation. Retrieved 15 October 2014.
[4] Free Pascal: Reference Guide. Free Pascal. Retrieved
15 October 2014.

6 Further reading
Peter Brass, Advanced Data Structures, Cambridge
University Press, 2008.
Donald Knuth, The Art of Computer Programming,
vol. 1. Addison-Wesley, 3rd edition, 1997.
Dinesh Mehta and Sartaj Sahni Handbook of
Data Structures and Applications, Chapman and
Hall/CRC Press, 2007.
Niklaus Wirth, Algorithms and Data Structures,
Prentice Hall, 1985.

7 External links
course on data structures
Data structures Programs Examples in c,java
UC Berkeley video course on data structures
Descriptions from the Dictionary of Algorithms and
Data Structures
Data structures course
An Examination of Data Structures from .NET perspective
Schaer, C. Data Structures and Algorithm Analysis

Text and image sources, contributors, and licenses

8.1

Text

Data structure Source: https://en.wikipedia.org/wiki/Data_structure?oldid=670523715 Contributors: LC~enwiki, Ap, -- April, Andre Engels, Karl E. V. Palmen, XJaM, Arvindn, Ghyll~enwiki, Michael Hardy, TakuyaMurata, Minesweeper, Ahoerstemeier, Nanshu, Kingturtle,
Glenn, UserGoogol, Jiang, Edaelon, Nikola Smolenski, Dcoetzee, Chris Lundberg, Populus, Traroth, Mrje, Bearcat, Robbot, Noldoaran,
Craig Stuntz, Altenmann, Babbage, Mushroom, Seth Ilys, GreatWhiteNortherner, Tobias Bergemann, Giftlite, DavidCary, Esap, Jorge
Stol, Siroxo, Pgan002, Kjetil r, Lancekt, Jacob grace, Pale blue dot, Andreas Kaufmann, Corti, Wrp103, MisterSheik, Lycurgus,
Shanes, Viriditas, Vortexrealm, Obradovic Goran, Helix84, Mdd, Jumbuck, Alansohn, Liao, Tablizer, Yamla, PaePae, ReyBrujo, Derbeth,
Forderud, Mahanga, Bushytails, Mindmatrix, Carlette, Ruud Koot, Easyas12c, TreveX, Bluemoose, Abd, Palica, Mandarax, Yoric~enwiki,
Qwertyus, Koavf, Ligulem, GeorgeBills, Husky, Margosbot~enwiki, Fragglet, RexNL, Fresheneesz, Butros, Chobot, Tas50, Banaticus,
YurikBot, RobotE, Hairy Dude, Piet Delport, Mipadi, Grafen, Dmoss, Tony1, Googl, Ripper234, Closedmouth, Vicarious, JLaTondre,
GrinBot~enwiki, TuukkaH, SmackBot, Reedy, DCDuring, Thunderboltz, BurntSky, Gilliam, Ohnoitsjamie, EncMstr, MalafayaBot, Nick
Levine, Frap, Allan McInnes, Khukri, Ryan Roos, Sethwoodworth, Er Komandante, SashatoBot, Demicx, Soumyasch, Antonielly, SpyMagician, Loadmaster, Noah Salzman, Mr Stephen, Alhoori, Sharcho, Caiaa, Iridescent, CRGreathouse, Ahy1, FinalMinuet, Requestion,
Nnp, Peterdjones, GPhilip, Pascal.Tesson, Qwyrxian, MTA~enwiki, Thadius856, AntiVandalBot, Widefox, Seaphoto, Jirka6, Dougher,
Tom 99, Lanov, MER-C, Wikilolo, Wmbolle, Rhwawn, Nyq, Wwmbes, David Eppstein, User A1, Cpl Syx, Oicumayberight, Gwern, MasterRadius, Rettetast, Lithui, Sanjay742, Rrwright, Marcin Suwalczan, Jimmytharpe, Santhy, TXiKiBoT, Eve Hall, Vipinhari, Coldre82,
DragonLord, Rozmichelle, Falcon8765, Spinningspark, Spitre8520, Haiviet~enwiki, SieBot, Caltas, Eurooppa~enwiki, Ham Pastrami,
Jerryobject, Flyer22, Strife911, Ramkumaran7, Nskillen, DancingPhilosopher, Digisus, Tanvir Ahmmed, ClueBot, Spellsinger180, Justin
W Smith, The Thing That Should Not Be, Rodhullandemu, Sundar sando, Garyzx, Adrianwn, Abhishek.kumar.ak, Excirial, Alexbot,
Erebus Morgaine, Arjayay, Morel, DumZiBoT, XLinkBot, Paushali, Pgallert, Galzigler, Alexius08, MystBot, Dsimic, Jncraton, MrOllie, EconoPhysicist, Publichealthguru, Mdnahas, Tide rolls, , Teles, , Legobot, Luckas-bot, Yobot, Fraggle81, AnomieBOT,
DemocraticLuntz, SteelPangolin, Jim1138, Kingpin13, Materialscientist, ArthurBot, Xqbot, Pur3r4ngelw, Miym, DAndC, RibotBOT,
Shadowjams, Methcub, Prari, FrescoBot, Liridon, Mark Renier, Hypersonic12, Rameshngbot, MertyWiki, Thompsonb24, Profvalente,
FoxBot, Laureniu Dasclu, Lotje, Bharatshettybarkur, Tbhotch, Thinktdub, Kh31311, Vineetzone, Uriah123, DRAGON BOOSTER,
EmausBot, Apoctyliptic, Thecheesykid, ZroBot, MithrandirAgain, EdEColbert, IGeMiNix, Mentibot, BioPupil, Chandraguptamaurya,
Rocketrod1960, Raveendra Lakpriya, Petrb, ClueBot NG, Aks1521, Widr, Danim, Jorgenev, Orzechowskid, Gmharhar, HMSSolent,
Wbm1058, Walk&check, Panchobook, Richfaber, SoniyaR, Yashykt, Cncmaster, Sallupandit, , Sgord512, Anderson,
Vishnu0919, Varma rockzz, Frosty, Hernan mvs, Forgot to put name, I am One of Many, Bereajan, Gauravxpress, Haeynzen, JaconaFrere,
Gambhir.jagmeet, Richard Yin, Jrachiele, Guturu Bhuvanamitra, TranquilHope, Iliazm, KasparBot, Ampsthatgoto11 and Anonymous:
356

8.2

Images

File:Commons-logo.svg Source: https://upload.wikimedia.org/wikipedia/en/4/4a/Commons-logo.svg License: ? Contributors: ? Original


artist: ?
File:Hash_table_3_1_1_0_1_0_0_SP.svg Source: https://upload.wikimedia.org/wikipedia/commons/7/7d/Hash_table_3_1_1_0_1_0_
0_SP.svg License: CC BY-SA 3.0 Contributors: Own work Original artist: Jorge Stol
File:Office-book.svg Source: https://upload.wikimedia.org/wikipedia/commons/a/a8/Office-book.svg License: Public domain Contributors: This and myself. Original artist: Chris Down/Tango project
File:Wikibooks-logo.svg Source: https://upload.wikimedia.org/wikipedia/commons/f/fa/Wikibooks-logo.svg License: CC BY-SA 3.0
Contributors: Own work Original artist: User:Bastique, User:Ramac et al.
File:Wikiquote-logo.svg Source: https://upload.wikimedia.org/wikipedia/commons/f/fa/Wikiquote-logo.svg License: Public domain
Contributors: ? Original artist: ?
File:Wikisource-logo.svg Source: https://upload.wikimedia.org/wikipedia/commons/4/4c/Wikisource-logo.svg License: CC BY-SA 3.0
Contributors: Rei-artur Original artist: Nicholas Moreau
File:Wikiversity-logo-Snorky.svg Source: https://upload.wikimedia.org/wikipedia/commons/1/1b/Wikiversity-logo-en.svg License:
CC BY-SA 3.0 Contributors: Own work Original artist: Snorky
File:Wiktionary-logo-en.svg Source: https://upload.wikimedia.org/wikipedia/commons/f/f8/Wiktionary-logo-en.svg License: Public
domain Contributors: Vector version of Image:Wiktionary-logo-en.png. Original artist: Vectorized by Fvasconcellos (talk contribs),
based on original logo tossed together by Brion Vibber

8.3

Content license

Creative Commons Attribution-Share Alike 3.0

Você também pode gostar