46. Permutations - LeetCode Solution


Array Backtracking

Python Code:

class Solution:
    def permute(self, nums: List[int]) -> List[List[int]]:
        ans = []
        
        def trav(data, i, length):
            if i ==length:
           
                ans.append(data.copy())
            else:
                for j in range(i, length):
                    data[i], data[j] =  data[j], data[i]
                    trav(data, i+1, length)
                    data[i], data[j] = data[j], data[i]
        
        trav(nums, 0, len(nums))
        return ans
            


Comments

Submit
0 Comments
More Questions

1445B - Elimination
1656C - Make Equal With Mod
567A - Lineland Mail
1553A - Digits Sum
1359B - New Theatre Square
766A - Mahmoud and Longest Uncommon Subsequence
701B - Cells Not Under Attack
702A - Maximum Increase
1656D - K-good
1426A - Floor Number
876A - Trip For Meal
1326B - Maximums
1635C - Differential Sorting
961A - Tetris
1635B - Avoid Local Maximums
20A - BerOS file system
1637A - Sorting Parts
509A - Maximum in Table
1647C - Madoka and Childish Pranks
689B - Mike and Shortcuts
379B - New Year Present
1498A - GCD Sum
1277C - As Simple as One and Two
1301A - Three Strings
460A - Vasya and Socks
1624C - Division by Two and Permutation
1288A - Deadline
1617A - Forbidden Subsequence
914A - Perfect Squares
873D - Merge Sort