Interview Question

# Generate All Permutations

## Course launching September 2020

**Follow me on YouTube** for free coding interview videos.

Users who sign up for the email list will receive an exclusive 75% discount at launch.

MENTION BACKTRACKING (look at video)

**Write a function generatePermutations that finds all the of an input string.**

- If there are duplicate letters, you should include the duplicate permutations of each.
- Time and space complexity is not considered for the quality of the solution - focus on readable code.

```
generatePermutations('dev')
// ['dev', 'dve', 'edv', 'evd', 'vde', 'ved']
// Notice you include duplicate permutations if there are duplicate letters
generatePermutations('bob')
// ['bob', 'bbo', 'bob', 'bbo', 'obb', 'obb']
```

**Interactive Permutation Animation**

### Validate My Answer

Our constraint says that the Big O complexity should not be factored into picking a solution. You will likely want to use recursion because the iterative solution is painfully long.

Duplicate strings are allowed in the result if they form the same permutation. You only need to focus on creating the logic for the permutations without needing to validate.

Any recursive solution must have a base case. Think through what it would be here and ensure it's included in your solution.