Universities

Computer Science: Algorithms, Theory, and Machines

Online Course Highlights
  • Princeton University via Coursera
  • Learn for FREE, Up-gradable
  • 20 hours of effort required
  • 50,056+ already enrolled!
  • 4.7 ★★★★★ (243 Ratings)
  • Skill Level: Intermediate
  • Language: English

This course introduces the broader discipline of computer science to people having basic familiarity with Java programming. It covers the second half of our book Computer Science: An Interdisciplinary Approach (the first half is covered in our Coursera course Computer Science: Programming with a Purpose, to be released in the fall of 2018). Our intent is to demystify computation and to build awareness about the substantial intellectual underpinnings and rich history of the field of computer science.

First, we introduce classic algorithms along with scientific techniques for evaluating performance, in the context of modern applications. Next, we introduce classic theoretical models that allow us to address fundamental questions about computation, such as computability, universality, and intractability. We conclude with machine architecture (including machine-language programming and its relationship to coding in Java) and logic design (including a full CPU design built from the ground up).

The course emphasizes the relationships between applications programming, the theory of computation, real computers, and the field’s history and evolution, including the nature of the contributions of Boole, Shannon, Turing, von Neumann, and others.

All the features of this course are available for free. No certificate will be offered upon completion.

Syllabus

WEEK 1

INFORMATION ABOUT LECTURES 1–10

  • 10 minutes to complete

This lesson provides information about the course Computer Science: Programming with a Purpose, which is the precursor to Computer Science: Algorithms, Theory, and Machines.

SORTING AND SEARCHING

  • 2 hours to complete

We introduce and study classic algorithms for two fundamental problems, in the context of realistic applications. Our message is that efficient algorithms (binary search and mergesort, in this case) are a key ingredient in addressing computational problems with scalable solutions that can handle huge instances, and that the scientific method is essential in evaluating the effectiveness of such solutions.

WEEK 2: STACKS AND QUEUES

  • 2 hours to complete

Our introduction to data structures is a careful look at the fundamental stack and queue abstractions, including performance specifications. Then we introduce the concept of linked structures and focus on their utility in developing simple, safe, clear, and efficient implementations of stacks and queues.

WEEK 3: SYMBOL TABLES

  • 2 hours to complete

The symbol table abstraction is one of the most important and useful programmer’s tools, s we illustrate with several examples in this lecture. Extending the scientific approach of the previous two lectures, we introduce and study binary search trees, a classic data structure that supports efficient implementations of this abstraction.

WEEK 4: INTRODUCTION TO THE THEORY OF COMPUTING

  • 2 hours to complete

The theory of computing helps us address fundamental questions about the nature of computation while at the same time helping us better understand the ways in which we interact with the computer. In this lecture, we introduce formal languages and abstract machines, focusing on simple models that are actually widely useful in practical applications.

WEEK 5: TURING MACHINES

  • 2 hours to complete

In 1936, Alan Turing published a paper that is widely hailed as one of the most important scientific papers of the 20th century. This lecture is devoted to the two far-reaching central ideas of the paper: All computational devices have equivalent computational power, and there are limitations to that power.

WEEK 6: INTRACTABILITY

  • 2 hours to complete

As computer applications expanded, computer scientists and mathematicians realized that a refinement of Turing’s ideas is needed. Which computational problems can we solve with the resource limitations that are inescapable in the real world? As described in this lecture, this question, fundamentally, remains unanswered.

WEEK 7: A COMPUTING MACHINE

  • 2 hours to complete

Every programmer needs understand the basic characteristics of the underlying computer processor being used. Fortunately, the fundamental design of computer processors has changed little since the 1960s. In this lecture, we provide insights into how your Java code actually gets its job done by introducing an imaginary computer that is similar to both the minicomputers of the 1960s and the microprocessor chips found in today’s laptops and mobile devices.

WEEK 8: VON NEUMANN MACHINES

  • 2 hours to complete

Continuing our description of processor design and low-level programming, we provide context stretching back to the 1950s and discuss future implications of the von Neumann machine, where programs and data are kept in the same memory. We examine in detail the idea that we design new computers by simulating them on old ones, something that Turing’s theory guarantees will always be effective.

WEEK 9: COMBINATIONAL CIRCUITS

  • 2 hours to complete

Starting with a few simple abstractions (wires that can carry on/off values and switches that can control the values carried by wires), we address in this lecture the design of the circuits that implement computer processors. We consider gates that implement simple logical functions and components for higher-level functions, such as addition. The lecture culminates with a full circuit for an arithmetic/logic unit.

WEEK 10: CENTRAL PROCESSING UNIT

  • 2 hours to complete

In this lecture, we provide the last part of our answer to the question “How does a computer work?” by developing a complete circuit for a computer processor, where every switch and wire is visible. While vastly different in scale, this circuit, from a design point of view, has many of the same characteristics as the circuits found in your computer and your phone.


More Related Courses:

Data Visualization for All (Course not available)
Trinity College via edX
6 Weeks of effort required
Skill Level: Introductory
★★★★★

Data Visualization and Communication with Tableau
Duke University via Coursera
25 hours of effort required
131,528 students enrolled!
★★★★★ (2,269 Ratings)
This Course is Part of Excel to MySQL: Analytic Techniques for Business Specialization

Fundamentals of Visualization with Tableau
University of California Davis via Coursera
72 hours of effort required
42,683 students enrolled!
★★★★★ (7,177 Ratings)
This Course is Part of Data Visualization with Tableau Specialization


Your Feedback:

There are no reviews yet. Be the first one to write one.


0.0
0.0 out of 5 stars (based on 0 reviews)
Excellent0%
Very good0%
Average0%
Poor0%
Terrible0%
Course Expert

Share
Published by
Course Expert

Recent Posts

Simple Tips to Help You Prepare for Employment After an Injury

It’s a tough reality: every year, over 14.1 million workers suffer from work-related injuries. For…

1 month ago

London’s Top 5 Cooking Courses for Beginners

If you’ve ever wanted to learn how to cook, but didn’t know where to start,…

1 month ago

The Role of Knowing Your International IQ Score in Choosing the Right Career Path

Choosing the right career path can be a daunting task, especially with the myriad of…

5 months ago

How HR Software Can Empower Your Business

Believe it or not, the concept of human resources has existed for more than 100…

5 months ago

Web3 in Gaming: Revolutionizing the Industry

Web3 managed to change the gaming industry by leveraging blockchain technology. It offers a decentralized…

6 months ago

Tips for Overcoming Homesickness in College

College is often fun and is filled with lots of activities, especially in the first…

6 months ago