数据结构与算法练习63

全排列2

在这里插入图片描述

解题思路:

和全排列一样,回溯思想,就是当有重复元素的时候要注意如何去重。

代码:

        public IList<IList<int>> PermuteUnique(int[] nums)
        {
            IList<IList<int>> result = new List<IList<int>>();
            if (nums.Length == 0)
                return result;
            IList<int> lgx = new List<int>();
            int[] choose = new int[nums.Length];
            Array.Sort(nums);
            phuisu(nums, choose, result, lgx);
            return result;
        }//全排列 II。
        public void phuisu(int[] nums,int[] choose,IList<IList<int>> result,IList<int> lgx)
        {
            if(lgx.Count==nums.Length)
            {
                result.Add(new List<int>(lgx));
                return;
            }
            for(int i=0;i<nums.Length;i++)
            {
                if (choose[i] == 1)
                    continue;
                choose[i] = 1;
                lgx.Add(nums[i]);
                phuisu(nums, choose, result, lgx);
                lgx.RemoveAt(lgx.Count - 1);
                choose[i] = 0;
                while (i<nums.Length-1&&nums[i + 1] == nums[i])
                    i++;//判断是否是相同元素,去重。
            }
        }//回溯。

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值