Sorted array

Array data structure


title: "Sorted array" type: doc version: 1 created: 2026-02-28 author: "Wikipedia contributors" status: active scope: public tags: ["arrays"] description: "Array data structure" topic_path: "general/arrays" source: "https://en.wikipedia.org/wiki/Sorted_array" license: "CC BY-SA 4.0" wikipedia_page_id: 0 wikipedia_revision_id: 0

::summary Array data structure ::

::data[format=table title="Infobox data structure"]

FieldValue
nameSorted array
typeArray
invented_byJohn von Neumann
invented_year1945
space_avgO(n)
space_worstO(n)
search_avgO(log n)
search_worstO(log n)
insert_avgO(n)
insert_worstO(n)
delete_avgO(n)
delete_worstO(n)
::

|name=Sorted array |type=Array |invented_by=John von Neumann |invented_year=1945 |space_avg=O(n) |space_worst=O(n) |search_avg=O(log n) |search_worst=O(log n) |insert_avg=O(n) |insert_worst=O(n) |delete_avg=O(n) |delete_worst=O(n)

A sorted array is an array data structure in which each element is sorted in numerical, alphabetical, or some other order, and placed at equally spaced addresses in computer memory. It is typically used in computer science to implement static lookup tables to hold multiple values which have the same data type. Sorting an array is useful in organising data in ordered form and recovering them rapidly.

Overview

Sorted arrays are the most space-efficient data structure with the best locality of reference for sequentially stored data.

Elements within a sorted array are found using a binary search, in O(log n); thus sorted arrays are suited for cases when one needs to be able to look up elements quickly, e.g. as a set or multiset data structure. This complexity for lookups is the same as for self-balancing binary search trees.

In some data structures, an array of structures is used. In such cases, the same sorting methods can be used to sort the structures according to some key as a structure element; for example, sorting records of students according to roll numbers or names or grades.

If one is using a sorted dynamic array, then it is possible to insert and delete elements. The insertion and deletion of elements in a sorted array executes at O(n), due to the need to shift all the elements following the element to be inserted or deleted; in comparison a self-balancing binary search tree inserts and deletes at O(log n). In the case where elements are deleted or inserted at the end, a sorted dynamic array can do this in amortized O(1) time while a self-balancing binary search tree always operates at O(log n).

Elements in a sorted array can be looked up by their index (random access) at O(1) time, an operation taking O(log n) or O(n) time for more complex data structures.

History

John von Neumann wrote the first array sorting program (merge sort) in 1945, when the first stored-program computer was still being built.

References

References

  1. [[Donald Knuth]], ''[[The Art of Computer Programming]]'', vol. 3. Addison-Wesley
  2. "Operating System Concepts by Peter B. Galvin". WILEY-INDIA Pvt. limited.

::callout[type=info title="Wikipedia Source"] This article was imported from Wikipedia and is available under the Creative Commons Attribution-ShareAlike 4.0 License. Content has been adapted to SurfDoc format. Original contributors can be found on the article history page. ::

arrays