How to do a topological sort from a subset of items from a given graph?

后端 未结 2 1488
谎友^
谎友^ 2021-01-24 12:52

I have the following problem: You are given a todo list, some items of which depend on others. Write a function that takes a subset of those todos and returns an ordered list of

2条回答
  •  滥情空心
    2021-01-24 13:10

    Don't think of this as a topological sort. Think of this as "do dependencies first, do not do them twice." Which is simple recursive function as long as we keep track of what we will do, and what has been done.

    The following Python solution may make this clearer.

    def arrange_tasks(dependencies, todo, in_order=None, done=None):
        if in_order is None:
            in_order = []
        if done is None:
            done = set()
    
        for item in todo:
            # Do we need to?
            if item not in done:
                # Marking it done first avoids deep recursion on dependency loops!
                done.add(item)
                # Make sure that dependencies happened.
                arrange_tasks(dependencies, dependencies[item], in_order, done)
                # And now this can happen.
                in_order.append(item)
        return in_order
    
    print(arrange_tasks(
        {
            'make a sandwich': ['buy groceries'],
            'buy groceries': ['go to store'],
            'go to store': []
        },
        ['buy groceries']
    ))
    

提交回复
热议问题