This is the third course in the Amazon Junior Software Developer Professional Certificate. In this course, you will gain a deep understanding of various fundamental data structures and algorithms essential for building efficient and scalable software solutions. Starting with Advanced Data Structures, you'll explore arrays, ArrayLists, linked lists, stacks, queues, and maps, understanding their implementations, operations, advantages, and use cases. Moving on to Searching and Sorting Algorithms, you'll manipulate essential algorithms like linear and binary search, as well as various sorting algorithms, including bubble sort, insertion sort, selection sort, merge sort, and quick sort.



Data Structures and Algorithms
This course is part of Amazon Junior Software Developer with GenAI Professional Certificate

Instructor: Amazon
Access provided by Université Mohammed VI des Sciences de la Santé (UM6SS)
17,080 already enrolled
(48 reviews)
Recommended experience
What you'll learn
- Identify, implement, and analyze the efficiency and performance of basic data structures and algorithms in Java. 
- Apply principles of recursion in Java to solve complex problems. 
- Implement search and sorting algorithms in Java to optimize data processing and retrieval. 
Skills you'll gain
Details to know

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

Build your Software Development 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 from Amazon

There are 4 modules in this course
In this module, you'll delve into fundamental data structures in Java, including Arrays, ArrayLists, LinkedLists, Stacks, and Queues. You'll start by understanding the basics of Arrays, focusing on their efficiency and limitations. Then, you'll explore ArrayLists and LinkedLists to learn how these dynamic data structures offer flexibility in managing collections of data. You'll also cover Stacks and Queues, mastering their use in scenarios that require Last-In-First-Out (LIFO) and First-In-First-Out (FIFO) operations, respectively. This module equips you with essential skills to effectively implement and utilize these data structures in real-world applications.
What's included
21 videos13 readings5 assignments1 programming assignment5 ungraded labs
In this module, you'll explore advanced algorithms in Java, focusing on efficient data management and retrieval techniques. You'll begin with HashMap, TreeMap, and LinkedHashMap, learning how these structures optimize data storage and access. Then, you'll dive into searching algorithms, mastering both Linear and Binary Search for quick data retrieval. The module also covers a range of sorting algorithms, including Bubble, Insertion, and Selection Sort, as well as more advanced techniques like Merge Sort and Quick Sort. This module equips you with the skills to implement and optimize algorithms for enhanced application performance.
What's included
27 videos11 readings5 assignments1 programming assignment8 ungraded labs
In this module, you'll explore essential software testing practices, covering both manual and automated testing. You'll begin with the fundamentals of software testing, understanding its importance in ensuring code quality. Next, you'll dive into version control with Git and GitHub, learning how to manage and collaborate on code efficiently. The module also covers JUnit Testing, where you'll gain hands-on experience writing and executing test cases in Java. Finally, you'll delve into Test-Driven Development (TDD), mastering the approach of writing tests before code to ensure robust and maintainable software development.
What's included
13 videos4 readings4 assignments1 programming assignment2 ungraded labs
In this module, you'll apply your knowledge of data structures and algorithms to a small project, allowing you to solve real-world problems efficiently. You'll start by selecting appropriate data structures like Arrays, LinkedLists, or HashMaps for the project's requirements. As you progress, you'll implement algorithms for tasks such as searching, sorting, and managing data flows. The project will challenge you to optimize your solutions for performance and scalability, reinforcing your understanding of how to integrate data structures and algorithms into practical applications. This hands-on experience will solidify your skills in developing efficient and effective code.
What's included
4 videos3 readings1 assignment1 programming assignment1 discussion prompt
Earn a career certificate
Add this credential to your LinkedIn profile, resume, or CV. Share it on social media and in your performance review.
Why people choose Coursera for their career




Learner reviews
48 reviews
- 5 stars66.66% 
- 4 stars25% 
- 3 stars2.08% 
- 2 stars4.16% 
- 1 star2.08% 
Showing 3 of 48
Reviewed on Jan 21, 2025
Provided a clear, engaging, and informative learning experience
Reviewed on Apr 11, 2025
Nicely Explained topics with good hands-on Lab exercises, Great course!
Reviewed on Feb 25, 2025
I learnt very new things as a beginner but there are more topics like Trees , Graphs , more sorting and searching algorithms that are not covered , so besides it , the course is good.
Explore more from Computer Science
 - University of California San Diego 




