Algorithms: Design and Analysis, Part 2

Tim Roughgarden, Stanford


About This Course

Welcome to the self paced course, Algorithms: Design and Analysis, Part 2! Algorithms are the heart of computer science, and the subject has countless practical applications as well as intellectual depth. This course is an introduction to algorithms for learners with at least a little programming experience. The course is rigorous but emphasizes the big picture and conceptual understanding over low-level implementation and mathematical details. After completing this course, you will have a greater mastery of algorithms than almost anyone without a graduate degree in the subject.

Specific topics in Part 2 include: greedy algorithms (scheduling, minimum spanning trees, clustering, Huffman codes), dynamic programming (knapsack, sequence alignment, optimal search trees, shortest paths), NP-completeness and what it means for the algorithm designer, analysis of heuristics, local search.

Learners will practice and master the fundamentals of algorithms through several types of assessments. There are 6 multiple-choice problem sets to test your understanding of the most important concepts. There are also 6 programming assignments, where you implement one of the algorithms covered in lecture in a programming language of your choosing. The course concludes with a multiple-choice final.

There are no assignment due dates and you can work through the course materials and assignments at your own pace.

Who This Course is For:

This course is aimed at learners with at least a little bit of programming experience who want to learn the essentials of algorithms. In a University computer science curriculum, this course is typically taken in the third year.

Course Staff

Tim Roughgarden

Tim Roughgarden has been a professor in the Computer Science Department at Stanford University since 2004. He has taught and published extensively on the subject of algorithms and their applications.

Frequently Asked Questions

Can I earn a Statement of Accomplishment

Yes. If you successfully complete at least 70% of the graded assignments in the course, you can receive a Statement of Accomplishment.

Share with friends and family! Tweet that you've registered for this course Email someone to say you've registered for this course
  1. Course Number

    Algorithms2 - SELF PACED
  2. Classes Start

    Sep 05, 2017
  3. Estimated Effort

    4 hrs / wk
  4. Price


Our Research Community

Stanford University pursues the science of learning. Online learners are important participants in that pursuit. The information we gather from your engagement with our instructional offerings makes it possible for faculty, researchers, designers and engineers to continuously improve their work and, in that process, build learning science.

By registering as an online learner, you are also participating in research...

Read Terms of Service and Privacy Policy.

  • 5 сентября 2017
Характеристики онлайн курса:
  • Бесплатный:
  • Платный:
  • Сертификат:
  • MOOC:
  • Видеолекции:
  • Аудиолекции:
  • Email-курс:
  • Язык: Английский Gb


Пока никто не написал отзыв по этому курсу. Хотите быть первым?

Зарегистрируйтесь, чтобы оставить отзыв

Ещё курсы на эту тему:
Small-icon.hover Algorithms: Design and Analysis, Part 1
In this course you will learn several fundamental principles of algorithm design...
Small-icon.hover Algorithms: Design and Analysis, Part 2
In this course you will learn several fundamental principles of advanced algorithm...
1-124jf00 Foundations of Software Engineering
This is a foundation subject in modern software development techniques for engineering...
393986_dded_11 Learn Data Structures & Algorithms : Earn $60k Per Year
Learn Data Structures and Algorithms in C++ =================> ( 9blast...
Caveman Genomic Data Science and Clustering (Bioinformatics V)
How do we infer which genes orchestrate various processes in the cell? How did...
Ещё из рубрики «Технические науки»:
Ewi_pv1x_378x225 Solar Energy: Photovoltaic (PV) Energy Conversion
Understand how solar cells generate electricity. Learn about semiconductor physics...
Course%20tile__mining3 Mining Engineering
Explore the many facets of mining engineering from exploration to production...
Regular_0a144d48-4415-4915-afd7-1db0e5b9d9fd The Earth in My Pocket: an Introduction to Geology
Get an introduction to geology. Discover where materials that make up everyday...
Regular_d3266e2c-e7c6-4645-82ff-95a4e213f499 Why Biology Matters: Basic Concepts
Improve your understanding of the complex biology behind social issues that...
Regular_d370e586-5c8a-4c80-9a90-4a79e9575a0d Blockchain in the Energy Sector
Understand how blockchain works, where the technology has come from and why...
Ещё от Stanford:
Nlp-logo CS224d: Deep Learning for Natural Language Processing
Natural language processing (NLP) is one of the most important technologies...
Asset-v1:humanitiessciences+sportsanduniversity+fall2017+type@asset+block@rose_bowl_smaller Sports and the University
Overview About This Course Sports are everywhere in US universities. Why is...
Visionlablogo CS231n: Convolutional Neural Networks for Visual Recognition
Computer Vision has become ubiquitous in our society, with applications in search...
Databases DB: Introduction to Databases
Learn about Databases, one of the most prevalent technologies underlying internet...
Envphys_water EP101: Your Body in the World: Adapting to Your Next Big Adventure
Discover the amazing adaptability of the human body to environmental stressors...

© 2013-2017