-
Notifications
You must be signed in to change notification settings - Fork 3.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
RFC: Add python alternative for algorithms course #81
Comments
There appear to be a few implementations of Sedgewick's Algorithms in Python: https://github.com/ChangeMyUsername/algorithms-sedgewick-python https://github.com/shellfly/algs4-py (this one is also available as a wheel on PyPI) And at least two more which primarily use Python 2.7, which I will not include here. Additionally, Sedgewick co-authored an Introduction to Programming in Python book, which includes a section in Algorithms and Data Structures (coverage of which is surprisingly deep for a CS1 course): https://introcs.cs.princeton.edu/python/40algorithms/ Therefore, I think one viable option is to continue recommending the book and course currently being suggested, and add this supplemental information to allow for a Python re-tread if students are interested. |
I'm not sure that this addresses the problem. The goal is to allow students to learn the algorithms content without the need to learn an additional programming language. The approach of adding these supplemental materials would better address the problem of 'students state that they have trouble translating what they have learned in one language into the work they do in another language'. |
How about https://www.coursera.org/learn/computational-thinking-problem-solving ? I haven't compared it to the current course myself but it does appear to teach algorithms and how to implement them. It expects Python as a language. |
I appreciate this RFC as I'm looking for an algorithms course and don't want to have to learn Java right now since I'm currently learning C# and recently learned some Python. I'll likely try the alternative course and at a glance think it's a good option to offer. My initial perusal of options found this track to be of interest because it appears to accept solutions in a variety of languages (including Python), though I don't know if it's comprehensive enough and course 4 has weak reviews: https://www.coursera.org/specializations/data-structures-algorithms#courses |
Thank you, I appreciate it lots, I will check it out.
…On Fri, Jul 23, 2021, 18:51 Nikhil ***@***.***> wrote:
I appreciate this RFC as I'm looking for an algorithms course and don't
want to have to learn Java right now since I'm currently learning C# and
recently learned some Python. I'll likely try the alternative course and at
a glance think it's a good option to offer.
My initial perusal of options found this track to be of interest because
it appears to accept solutions in a variety of languages (including
Python), though I don't know if it's comprehensive enough and course 4 has
weak reviews:
https://www.coursera.org/specializations/data-structures-algorithms#courses
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub
<#81 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ARFC7VZS757CRUFOQQP4FY3TZGT2HANCNFSM5AFAECTQ>
.
|
MIT 6.006 was released for Spring 2020 which features Algorithms in Python 3. This seems like it could be an okay fix, except one of the two prerequisite courses 6.042J would need to be added. Adding 6.042J seems like it's counter to the curricular guidelines of "an efficient data science major should present these mathematical concepts in two courses, in the context of modeling for data-driven problems" (section 2.5). This would add another math course to the 3-4 we already have listed. I'm not sure which has more merit, learning Java to take an algorithms course or learning math to take an algorithms course. |
Also, while the curricular guidelines do not require students to learn multiple languages. The appendix to the curricular guidelines, or the envisioned course structure based on the guidelines, actually states "Learn a second programming language (e.g., Python, C++, Java)" as a learning of the Algorithms and Software Concepts course. They list Python here as a second programming language because R is recommended for the Intro to DS courses. |
The Curriculum Guidelines describe "algorithm design" and "programming concepts and data structures":
The Curriculum's P.S. I support this RFC, but the lack of official solutions for this RFC's proposed course would be problematic for learners. |
https://jovian.ai/learn/data-structures-and-algorithms-in-python I found this course to be very helpful |
I believe that the fundamental ideas behind algorithms are the same. So, either Java, C++, or possibly Python is good. |
Came across this RFC by browsing If you are searching for DSA course in python https://nptel.ac.in/courses/106106145 by IIT Madras . This is also same course that IIT Madras offers in online data science degree that I am currently attending. https://onlinedegree.iitm.ac.in/course_pages/BSCCS2002.html |
https://www.edx.org/learn/algorithms/stanford-university-algorithms-design-and-analysis-part-1 |
Is there a reason the algorthms are different from the stanford Algorithms Specialization on the OSSU computer science degree ?(https://www.coursera.org/specializations/algorithms). Why are the classes different between the two programs? |
Different levels of prep for the topic. The Stanford/Roughgarden courses are generally more advanced than the Princeton/Sedgewick courses. The CS curriculum recommends 13 courses preceding the algorithms course, many of which discuss algorithms. The DS curriculum recommends 3. |
CS has a discrete math course. DS does not. |
Problem:
Our curricular guidelines do not require learning multiple languages, but our curriculum asks students to learn a language just to take the algorithms classes.
Duration:
2021 Aug 15
Background:
Our curricular guidelines makes only a few references to programming languages. Students are expected to know SQL, the "language" of math, and "a suitable high-level language". (emphasis mine) The introductory courses, and most courses, use Python as this high level language.
But students are directed to Robert Sedgewick's Algorithms course, which is taught in Java.
Students have asked for a python alternative in issues and in the discord (example).
A possible option is the free interactive textbook Problem Solving with Algorithms and Data Structures using Python. The book links to a set of supporting lectures. It also has some exercises in the text, which are paired with youtube video solutions. Each chapter ends with a set of exercises; it does not seem that there is an official solution set but some student solutions can be found on github.
This free textbook is used by dozens of college courses. It is well rated by goodreads and by pythonbooks (which is really a measure of popularity on Amazon).
It is not clear that the book is of the same quality as the Sedgwick course. For one, the Sedgewick course provides an autograder. For another, user ratings of the Sedgewick Algorithms book are notably higher.
Proposal:
Offer Problem Solving with Algorithms and Data Structures using Python as an alternative Algorithms course for students who want to study in Python.
Alternatives:
The text was updated successfully, but these errors were encountered: