University of California San Diego
Mathematical Thinking in Computer Science
University of California San Diego

Mathematical Thinking in Computer Science

Alexander S. Kulikov
Michael Levin
Владимир Подольский

Instructors: Alexander S. Kulikov

Access provided by Yale

145,040 already enrolled

Gain insight into a topic and learn the fundamentals.
4.4

(2,272 reviews)

Beginner level
No prior experience required
Flexible schedule
4 weeks at 10 hours a week
Learn at your own pace
88%
Most learners liked this course
Gain insight into a topic and learn the fundamentals.
4.4

(2,272 reviews)

Beginner level
No prior experience required
Flexible schedule
4 weeks at 10 hours a week
Learn at your own pace
88%
Most learners liked this course

Details to know

Shareable certificate

Add to your LinkedIn profile

Assessments

57 assignments

Taught in English

See how employees at top companies are mastering in-demand skills

 logos of Petrobras, TATA, Danone, Capgemini, P&G and L'Oreal

Build your subject-matter expertise

This course is part of the Introduction to Discrete Mathematics for Computer Science Specialization
When you enroll in this course, you'll also be enrolled in this Specialization.
  • Learn new concepts from industry experts
  • Gain a foundational understanding of a subject or tool
  • Develop job-relevant skills with hands-on projects
  • Earn a shareable career certificate

There are 6 modules in this course

Why are some arguments convincing and some others are not? What makes an argument convincing? How can you establish your argument in such a way that there is no room for doubt left? How can mathematical thinking help with this? In this section, we start digging into these questions. Our goal is to learn by examples how to understand proofs, how to discover them on your own, how to explain them, and — last but not least — how to enjoy them: we will see how a small remark or a simple observation can turn a seemingly non-trivial question into an obvious one.

What's included

10 videos6 readings4 assignments

How can we be certain that an object with certain requirements exist? One way to show this, is to go through all objects and check whether at least one of them meets the requirements. However, in many cases, the search space is enormous. A computer may help, but some reasoning that narrows the search space is important both for computer search and for "bare hands" work. In this module, we will learn various techniques for showing that an object exists and that an object is optimal among all other objects. As usual, we'll practice solving many interactive puzzles. We'll show also some computer programs that help us to construct an example.

What's included

16 videos6 readings13 assignments

We'll discover two powerful methods of defining objects, proving concepts, and implementing programs — recursion and induction. These two methods are heavily used in discrete mathematics and computer science. In particular, you will see them frequently in algorithms — for analysing correctness and running time of algorithms as well as for implementing efficient solutions. For some computational problems (e.g., exploring networks), recursive solutions are the most natural ones. The main idea of recursion and induction is to decompose a given problem into smaller problems of the same type. Being able to see such decompositions is an important skill both in mathematics and in programming. We'll hone this skill by solving various problems together.

What's included

3 videos13 readings9 assignments1 ungraded lab

Mathematical logic plays a crucial and indispensable role in creating convincing arguments. We use the rules and language of mathematical logic while writing code, while reasoning and making decisions, and while using computer programs. This week we’ll learn the basics of mathematical logic, and we'll practice tricky and seemingly counterintuitive, but yet logical aspects of mathematical logic. This will help us to write readable and precise code, and to formulate our thoughts rigorously and concisely.

What's included

10 readings10 assignments

"There are things that never change". Apart from being just a philosophical statement, this phrase turns out to be an important idea in discrete mathematics and computer science. A property that is preserved during a process is called an invariant. Invariants are used heavily in analyzing the behavior of algorithms, programs, and other processes. Being able to find the right invariant is an important skill that we will develop together in this module.

What's included

11 readings16 assignments

In this module, we consider a well-known 15-puzzle where one needs to restore order among 15 square pieces in a square box. It turns out that the behavior of this puzzle is determined by mathematics: it is solvable if and only if the corresponding permutation is even. To understand what it means and why it is true, we will learn the basic properties of even and odd permutations — an important notion in algebra and discrete mathematics. Together, we will implement a number of simple methods for working with permutations. You will then use them as building blocks to implement a program that solves any configuration of this game in the blink of an eye!

What's included

8 videos4 readings5 assignments

Earn a career certificate

Add this credential to your LinkedIn profile, resume, or CV. Share it on social media and in your performance review.

Instructors

Instructor ratings
4.3 (468 ratings)
Alexander S. Kulikov
University of California San Diego
13 Courses862,282 learners
Michael Levin
University of California San Diego
8 Courses816,590 learners
Владимир Подольский
8 Courses233,980 learners

Offered by

Why people choose Coursera for their career

Felipe M.
Learner since 2018
"To be able to take courses at my own pace and rhythm has been an amazing experience. I can learn whenever it fits my schedule and mood."
Jennifer J.
Learner since 2020
"I directly applied the concepts and skills I learned from my courses to an exciting new project at work."
Larry W.
Learner since 2021
"When I need courses on topics that my university doesn't offer, Coursera is one of the best places to go."
Chaitanya A.
"Learning isn't just about being better at your job: it's so much more than that. Coursera allows me to learn without limits."

Learner reviews

4.4

2,272 reviews

  • 5 stars

    64.23%

  • 4 stars

    23.36%

  • 3 stars

    7.08%

  • 2 stars

    2.11%

  • 1 star

    3.21%

Showing 3 of 2272

MI
5

Reviewed on Sep 15, 2020

DG
5

Reviewed on Jun 29, 2018

DS
5

Reviewed on Nov 6, 2022

Explore more from Computer Science