Algorithm (nonfiction)

From Gnomon Chronicles
Revision as of 08:22, 16 December 2015 by Admin (talk | contribs) (Created page with "In mathematics (nonfiction) and computer science (nonfiction), an '''algorithm''' is a self-contained step-by-step set of Operation (nonfiction)|operations (nonficti...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

In mathematics (nonfiction) and computer science (nonfiction), an algorithm is a self-contained step-by-step set of operations (nonfiction) to be performed.

Description

Algorithms exist that perform calculation (nonfiction), data processing (nonfiction), and automated reasoning (nonfiction).

An algorithm is an effective method that can be expressed within a finite amount of space (nonfiction) and time (nonfiction) and in a well-defined formal language (nonfiction) for calculating a mathematical function (nonfiction).

Process

Starting from an initial state (nonfiction) and initial input (nonfiction) (perhaps empty (nonfiction)), the instructions (nonfiction) describe a computation (nonfiction) that, when executed (nonfiction), proceeds through a finite number (nonfiction) of well-defined successive states (nonfiction), eventually producing output (nonfiction) and terminating at a final ending state (nonfiction).

Randomized algorithms

The transition from one state (nonfiction) to the next is not necessarily deterministic; some algorithms, known as randomized algorithms (nonfiction), incorporate random input (nonfiction).

History

The concept of algorithm has existed for centuries, however a partial formalization of what would become the modern algorithm began with attempts to solve the Entscheidungsproblem (nonfiction) (the "decision problem") posed by David Hilbert (nonfiction) in 1928.

Effective calculability

Subsequent formalizations were framed as attempts to define "effective calculability" or "effective method".

Those formalizations included:

Giving a formal definition of algorithms, corresponding to the intuitive notion, remains a challenging problem.

Algorithm analysis

Analysis of algorithms (nonfiction) is an important part of a broader computational complexity theory (nonfiction), which provides theoretical estimates for the resources needed by any algorithm which solves a given computational problem (nonfiction).

These estimates provide an insight into reasonable directions of search for algorithmic efficiency (nonfiction).

Nonfiction cross-reference

Fiction cross-reference

External links