This project contains a skeleton for you to implement some graph functionality. This is a test-driven project. Run the tests and read the top-most error. If it’s not clear what is failing, open the test/test.js file to figure out what the test is expecting. Make the top-most test pass.
Keep making the top-most test pass until all tests pass.
After the instructions, there is an in-depth explanation of the “friends of” problem.
cd
into the project foldernpm install
to install dependencies in the project root directorynpm test
to run the specstest/test.js
. Your job is to write code in
breadthFirstSearch
function for graphsmaxValue
function for graphsnumRegions
function for graphsfriendsOf
and friendsOfRecursion
to find connected nodes in a graph less than or equal to a specified distance away from the start node (please see the explanation after these instructions)canFinish
function located at https://leetcode.com/problems/course-schedule/The set of tests in test/friends-of-spec.js asks you to write a function named friendsOf
that finds the total set of friends a specified distance away from a person. It will take as parameters
The following table interprets the distance parameter:
Distance | Meaning |
---|---|
1 | Immediate friends |
2 | Immediate friends and friends of friends |
3 | Immediate friends, friends of friends, and the friends of friends of friends |
n | All the people accessible n steps away from the indicated person |
For example, say you had the following dependency graph.
const graph = {
'carrie': ['humza', 'jun'],
'farrah': ['humza'],
'humza': ['carrie', 'farrah', 'jun', 'silla'],
'jun': ['carrie', 'silla'],
'ophelia': ['travis'],
'silla': ['humza', 'yervand'],
'travis': ['ophelia'],
'yervand': ['silla'],
};
Then, the following table shows the expected results for the person jun at different distances.
Distance | List of people returned by friendsOf |
---|---|
1 | carrie and silla |
2 | carrie, silla, humza, yervand |
3 | carrie, silla, humza, yervand, farrah |
4 | carrie, silla, humza, yervand, farrah |
At distance 1, your traversal algorithm will find the friends of jun, carrie and silla and return them.
At distance 2, your traversal algorithm will find carrie and silla, then find their friends, humza and jun for carrie, and humza and yervand for silla. But, jun is the person that you started with, so you don’t include them in the return value. Humza is both carrie’s and silla’s friend, but you only include that name once.
At a distance 3, you find carrie and silla, then humza and yervand. Then, looking at humza’s friends, you see that humza knows carrie, farrah, hun, and silla. Only farrah is new, so that name will end up in the return value. When your traversal looks at yervand, it sees that silla is that person’s friend, but is not a new value and does not end up getting added again to the return value.
At a distance four, you find carrie and silla, then humza and yervand, then farrah. From there, you look at farrah’s friends which is just humza. You already have that name, so it doesn’t get duplicated in the return value.
All distances 3 and greater will return the same list because you’ve exhausted all of the distinct names of people. You’ve captured the entire circle of friends.
The order in which you return the names is not important.
The tests also define edge cases that you also have to handle that are not in this explanation.