Chevron Left
Back to Data Structures

Learner Reviews & Feedback for Data Structures by University of California San Diego

4.6
stars
5,548 ratings

About the Course

A good algorithm usually comes together with a set of good data structures that allow the algorithm to manipulate the data efficiently. In this online course, we consider the common data structures that are used in various computational problems. You will learn how these data structures are implemented in different programming languages and will practice implementing them in our programming assignments. This will help you to understand what is going on inside a particular built-in implementation of a data structure and what to expect from it. You will also learn typical use cases for these data structures. A few examples of questions that we are going to cover in this class are the following: 1. What is a good strategy of resizing a dynamic array? 2. How priority queues are implemented in C++, Java, and Python? 3. How to implement a hash table so that the amortized running time of all operations is O(1) on average? 4. What are good strategies to keep a binary tree balanced? You will also learn how services like Dropbox manage to upload some large files instantly and to save a lot of storage space!...

Top reviews

DG

May 24, 2016

I like this course very much! Rope is the cleverest task I have ever done! Of course, I hope in future I will work on even more difficult problems, but this is pretty good already for me as a student!

PS

Jul 10, 2020

I think the course content and assignments were great. A suggestion though, it will be more helpful if there are more and varied corner cases that would save time spent in thinking and making cases.

Filter by:

851 - 875 of 933 Reviews for Data Structures

By Sirojbek O

Oct 4, 2024

good

By SHAZIB A

May 24, 2023

good

By K R

Nov 15, 2021

Good

By GADU R

Jul 25, 2021

good

By KONDURU M 2

Jul 24, 2021

good

By Himanshu S

Jun 2, 2021

GOOD

By Asha D

May 28, 2021

nice

By Madappa B

Apr 21, 2021

good

By K S

Dec 15, 2020

good

By DEVIREDDY R S

Nov 27, 2020

Good

By 321910302007 g

Nov 27, 2020

good

By KONJETI S S V

Nov 24, 2020

good

By Pratik H

Sep 30, 2020

Nice

By Sarath C

Jul 29, 2020

good

By chaluvadi a

Jul 14, 2020

good

By SHIVAM G

Jul 4, 2019

good

By Tushar C

Oct 19, 2024

...

By 221910303021 G C

Jan 20, 2021

gg

By Vanshika K

Nov 2, 2020

NA

By ABHINAV C

Nov 17, 2024

.

By Andrey T

Jun 11, 2016

[Slightly updated according to Michael's questions]

The course is fine, but comparing to the previous one - Algorithmic Toolbox - this one is weaker and with lesser quality.

Pros: the course contains some interesting data structures and valuable observations. The starter files for assignments are in place. Related books are given after each video session. All the tasks have automatic grader. There is a couple of interesting tasks to do.

Cons: the material is mostly lectures, and there is even a video where lecturer just reads the article from Wiki (Splay tree - has the same information with same lack of some proofs). Expected: add quizzes as it was in the first course. The course has less weeks - only 4 as comparing to 5 in AT. So various important data structures are not discussed. The course has less homework - 3 tasks each week as comparing to 5 in AT. And all 3 are usually just implementations of some basic algos seen in lectures.

I consider the course valuable due to a number of good videos and a couple of good tasks to do. But in general, this course has the area for improvement.

By Vlad

May 14, 2016

The structure of the class follows the regular academic model you'll find in college: lecture -> lecture -> lecture -> assignment... repeat. I don't think this model is suitable for online delivery. Without discussion and the ability to interrupt and ask questions, the lectures are at times a more frustrating than useful (especially with Coursera's user interface, which lacks quick rewind and is generally speaking rather poorly thought out).

For many of the topics, better videos exist online (try safari or pluralsight). As for the problems, they were the main source of learning, but were also at times a bit frustrating (the splay trees starter code was rather sad to look at). I find that hacker rank is probably better at delivering value (if you can forego the warm fuzzy feeling you get from getting a verified certificate, you'll probably be better served by practicing on hacker rank than from doing the problems in this course).

By Pancerny M

Apr 1, 2020

Great set of topics, really good programming challenges. Lectures are NOT very helpful, mostly reading pseudocode from slides which don't make it easy to grasp the concept. Mostly I had to use other resources to understand what the lecture is about. Also, I was hoping that programming tasks will be set up the same way as in the Algorithmic Toolbox course where I could import/submit automatically everything to Coursera. For this course, none of the exercises were available in Pycharm for Edu.

By Zhongyu K

May 27, 2016

The depth and explanation of theoretical concepts are better than the first course. I like the in depth discussion over various introduced data structures, for instance there are comparisons between naive implementations vs smarter implementations. However overall the topic is very theoretical, maybe add a little more connection of each introduced data structure with respect to its application would make the topic less dry and more motivating.

By Ashley F

Jan 23, 2018

During this course, my experience was that the lectures and course notes did not seem to equip me to answer the quiz questions. While I was able to complete the practical assignments fine, I found the quizzes to be much harder and in some cases I needed to guess my way past. This may simply reflect a difficulty on my part to properly learn the material. Thanks to the authors for an interesting course, regardless!