#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param num int整型一维数组 
# @return int整型二维数组
#
class Solution:
    def permute(self , num: List[int]) -> List[List[int]]:
        # write code here
        n, ans = len(num), []
        def dfs(start):
            if start==n-1:
                ans.append(num[:])
            for i in range(start,n):#从第i位开始固定
                num[start], num[i] = num[i], num[start]#固定第i位
                dfs(start+1)
                num[start], num[i] = num[i], num[start]#复原第i位
        dfs(0)
        return ans