Introduces number-theory based cryptography, basics of quantum algorithms and advanced data-structures.



Advanced Data Structures, RSA and Quantum Algorithms
This course is part of Foundations of Data Structures and Algorithms Specialization

Instructor: Sriram Sankaranarayanan
Access provided by Coursera Guided Projects Instructors
5,286 already enrolled
(37 reviews)
Recommended experience
What you'll learn
- Explore how basic number-theoretic concepts are used to build the RSA crypto-system. 
- Examine the foundations of quantum computation and its basic building blocks. 
- Explore how quantum computers can be used to break the RSA cryptosystem. 
- Explore the differences between classical and quantum algorithms. 
Skills you'll gain
Details to know

Add to your LinkedIn profile
11 assignments
See how employees at top companies are mastering in-demand skills

Build your subject-matter expertise
- 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 4 modules in this course
This module covers a brief recap of elementary number theory, GCD, Euclid's algorithm, Bezout coefficients and presents the RSA public key cryptosystem. It then shows how the security of RSA relies on the supposed hardness of the factoring problem for numbers that are semi-primes
What's included
5 videos4 readings4 assignments1 programming assignment2 ungraded labs
This module covers the basics of quantum computing with an introduction to qubits, the concept of a superposition, the effect of measuring a qubit, elementary quantum gates, direct/tensor products, entanglements, quantum parallelism and ends with a presentation of Grover's search algorithm. We will have a brief introduction to IBM qiskit package for exploring quantum circuits.
What's included
8 videos5 assignments1 programming assignment3 ungraded labs
We will describe Shor's algorithm and as part of Shor's algorithm show how Quantum Fourier Transform (a very useful operation for quantum systems) is computed. We will show how the power of quantum parallelism combines with the divide-and-conquer paradigm for algorithm design to yield exponential speedups for computing Quantum Fourier Transforms.
What's included
7 videos1 reading2 assignments1 programming assignment2 ungraded labs
We will learn two important and interesting data structures to round off this course. The first data structure will be the widely used B-Tree data structure which is used in indexing and storing large amounts of data on a disk. Next, we will study algorithms on strings esp. string search algorithm. We will study the suffix trie data structure: a very useful data structure for fast searching over strings.
What's included
12 videos1 programming assignment2 ungraded labs
Earn a career certificate
Add this credential to your LinkedIn profile, resume, or CV. Share it on social media and in your performance review.
Build toward a degree
This course is part of the following degree program(s) offered by University of Colorado Boulder. If you are admitted and enroll, your completed coursework may count toward your degree learning and your progress can transfer with you.¹
Instructor

Offered by
Why people choose Coursera for their career




Learner reviews
37 reviews
- 5 stars81.08% 
- 4 stars8.10% 
- 3 stars2.70% 
- 2 stars5.40% 
- 1 star2.70% 
Showing 3 of 37
Reviewed on Aug 11, 2024
Great specialization, as close to a real university course series as possible in this online setting.
Reviewed on Nov 23, 2024
Amazing teaching, well made tasks and assessments. However, some computing task takes quite a while, a lot of code to familiarize with before you can solve the problems.
Explore more from Computer Science
 - University of Colorado Boulder 
 - University of Colorado Boulder 
 - University of Colorado Boulder 


