Computer Science: Algorithms, Complexity, and Pioneers

Classified in Computers

Written at on English with a size of 4.6 KB.

Algorithm Complexity

  • O(1): Parity Check
  • O(log n): Binary Search
  • O(n): Sequential Search
  • O(n log n): QuickSort
  • O(n2): Bubble Sort

Computer Science Fields

Theoretical Computer Science

  • Mathematical Logic
  • Automata Theory
  • Computability
  • Computational Complexity
  • Cryptography
  • Combinatorial Optimization

Practical Computer Science

  • Artificial Intelligence
  • Computer Architecture
  • Computer Graphics
  • Databases
  • Software Engineering
  • Distributed Systems
  • Computer Security
  • Human-Computer Interaction

Turing Machine Elements

  • Possible States
  • Initial State
  • Final State
  • Current State
  • Finite Set of Symbols
  • Input Symbols

Abstract Machines

Theoretical models for analyzing computability and algorithm complexity. Includes Automata and State Machines.

Deterministic Turing Machine (DTM)

For each state, there is only one transition.

Non-Deterministic Turing Machine (NDTM)

For one or more states, there can be multiple transitions.

Complexity Classes

  • Feasible: Problems solvable by DTM (O(log n)), NDTM (O(log n)), or DTM (O(nk)).
  • Maybe Not Feasible: NP (Non-deterministic Polynomial Time) optimization problems, NP-Complete problems.
  • Not Feasible: EXPTIME problems requiring DTM with O(2pn) time, NEXPTIME problems requiring NDTM with unlimited space.

Pioneers in Computing

  • Tim Berners-Lee (1955, British): World Wide Web, HTTP protocol.
  • Vint Cerf (1943, American): Father of the Internet, TCP/IP protocol.
  • Bob Kahn (1938, American): Father of the Internet, TCP/IP protocol.
  • James Gosling (1955, Canadian): Design and implementation of Java.
  • Donald Norman (1935, American): Human-Computer Interaction, user-centered design.
  • Ted Nelson (1937, American): Concepts of Hypertext & Hypermedia.
  • Douglas Engelbart (1925 – 2013, American): Invented the mouse, hypertext pioneer.
  • Bjarne Stroustrup (1950, Danish): Design and implementation of C++.
  • James Rumbaugh (1947, American): Object-Oriented Modeling (OMT), UML.
  • Alan Kay (1940, American): Object-oriented programming (Smalltalk), GUI, laptop & tablet concepts.
  • Ken Thompson (1943, American): UNIX, UTF-8 code.
  • Dennis Ritchie (1941 – 2011, American): C language, UNIX.
  • Niklaus Wirth (1934, Swiss): Structured programming languages (PL/0, PASCAL).
  • Donald D. Chamberlin (1944 – 2003, American): SQL, with Raymond Boyce.
  • Edgar F. Codd (1923 – 2003, British): Databases (relational model).
  • Donald Knuth (1938, American): Algorithm Analysis, The Art of Computer Programming, data structures.
  • Edsger W. Dijkstra (1930 – 2002, Dutch): Structured programming, recursion (ALGOL 60).
  • John McCarthy (1927 – 2011, American): Artificial Intelligence, functional programming (LISP), trees (data structures).
  • Seymour Cray (1925 – 1996, American): Design of Supercomputers, parallel computing.
  • Peter Naur (1928, Danish): Programming language syntax description, first language with programming structures (ALGOL), fundamentals of software engineering.
  • John Backus (1924 – 2007, American): First widely used programming language (FORTRAN), formal notation for defining programming languages.
  • Noam Chomsky (1928, American): Formal Languages, formal grammars, political activist.
  • Claude Shannon (1916 - 2001, American): Information Theory, game theory, digital circuits design.
  • John Vincent Atanasoff (1903 - 1995, American): First electronic digital computer (ABC).
  • Konrad Zuse (1910 - 1995, German): First electromechanical programmable computer.
  • John von Neumann (1903 – 1957, Hungarian): Digital computer architecture, merge sort.
  • Norbert Wiener (1894 - 1964, American): Electronic control, fundamentals of robotics, cybernetics.

Entradas relacionadas: