Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

Python Python Collections (2016, retired 2019) Sets Set Math

I don't understand where I am wrong

I was working on a code challenge but I couldn't figure out how to get it to work. I think my solution is correct but according to the corrector it is wrong. It says that it didn't get the right output from "covers". Please help.

"Challenge Task 1 of 2 Let's write some functions to explore set math a bit more. We're going to be using this COURSES dict in all of the examples. Don't change it, though! So, first, write a function named covers that accepts a single parameter, a set of topics. Have the function return a list of courses from COURSES where the supplied set and the course's value (also a set) overlap. For example, covers({"Python"}) would return ["Python Basics"]."

sets.py
COURSES = {
    "Python Basics": {"Python", "functions", "variables",
                      "booleans", "integers", "floats",
                      "arrays", "strings", "exceptions",
                      "conditions", "input", "loops"},
    "Java Basics": {"Java", "strings", "variables",
                    "input", "exceptions", "integers",
                    "booleans", "loops"},
    "PHP Basics": {"PHP", "variables", "conditions",
                   "integers", "floats", "strings",
                   "booleans", "HTML"},
    "Ruby Basics": {"Ruby", "strings", "floats",
                    "integers", "conditions",
                    "functions", "input"}
}

def covers(topics):
    listing = []
    for thing in COURSES.items():
        a, b = thing
        if topics.intersection(b) == topics:
            listing.append(a)
    return listing

3 Answers

if topics.intersection(b) == topics:

I think, the Challenge is looking for overlaps including partial overlaps as well. So, we should easing the above condition as below to allow partial overlaps as well.

if topics.intersection(b) == True: 
##OR 
if topics.intersection(b):

Thank you! That really helped.

Jay Padzensky
Jay Padzensky
4,731 Points

Hey Kevin,

I may recommend taking a peek at some of the previously created threads on the CC to perhaps get some insight into the task. Thanks, best of luck with it. Keep it up!

Hasan Ahmad
Hasan Ahmad
6,727 Points

Can someone walk me through every line of code so I can fully understand what's going on? I'm struggling a bit to understand.