当前位置: 首页 > news >正文

网站与新媒体建设测评方案上海做网站搜索一下马来西亚的

网站与新媒体建设测评方案,上海做网站搜索一下马来西亚的,网站制作的基础,南昌网站排名优化报价题目描述 全排列 给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1: 输入:nums [1,2,3] 输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2: 输入…

题目描述

全排列

给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。

示例 1:

输入:nums = [1,2,3]
输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

示例 2:

输入:nums = [0,1]
输出:[[0,1],[1,0]]

示例 3:

输入:nums = [1]
输出:[[1]]

提示:

  • 1 <= nums.length <= 6
  • -10 <= nums[i] <= 10
  • nums 中的所有整数 互不相同

解法

回溯法

这个问题可以看作有 n 个排列成一行的空格,我们需要从左往右依此填入题目给定的 n 个数,每个数只能使用一次。那么很直接的可以想到一种穷举的算法,即从左往右每一个位置都依此尝试填入一个数,看能不能填完这 n 个空格,在程序中我们可以用「回溯法」来模拟这个过程。

定义回溯函数:

private void backtrack(int n, List<Integer> output, ArrayList<List<Integer>> res, int first) {
}

first为当前要填的位置,n位需要填的总位置数。

  • 如果 first=n,说明已经填完了 n 个位置(注意下标从 0 开始),找到了一个可行的解,将 output 放入答案数组中,递归结束。
  • 如果first < n,填第 first 个数的时候遍历题目给定的 n 个数,如果这个数没有被标记过,就尝试填入,并将其标记,继续尝试填下一个位置。
  • 假设我们已经填到第 first 个位置,那么 nums 数组中 [0,first−1]是已填过的数的集合,[first,n−1] 是待填的数的集合。

java代码:

class Solution {/*** 回溯** @param nums* @return*/public List<List<Integer>> permute(int[] nums) {ArrayList<List<Integer>> res = new ArrayList<>();// nums不好交换位置,使用ListList<Integer> output = new ArrayList<Integer>();for (int num : nums) {output.add(num);}int n = nums.length;// 使用回溯backtrack(n, output, res, 0);return res;}/*** 回溯算法:*  如果 first=n,说明已经填完了 n 个位置(注意下标从 0 开始),找到了一个可行的解,将 output 放入答案数组中,递归结束。*  如果first < n,填第 first 个数的时候遍历题目给定的 n 个数,如果这个数没有被标记过,就尝试填入,并将其标记,继续尝试填下一个位置*  假设我们已经填到第 first 个位置,那么 nums 数组中 [0,first−1]是已填过的数的集合,[first,n−1] 是待填的数的集合*** @param n  原数组长度,也是结果数组最后的总长度* @param output  当前的数组* @param res  结果数组* @param first  当前位置*/private void backtrack(int n, List<Integer> output, ArrayList<List<Integer>> res, int first) {// 已经填完了 n 个位置,将 output 放入答案数组中,递归结束if (first == n) {// 注意这里的output,每次递归是公用的,所以需要把它放入新列表再放到结果列表res.add(new ArrayList<>(output));}// 开始填第first个数for (int i = first; i < n; i++) {// 动态维护数组,交换位置Collections.swap(output, first, i);// 继续递归填下一个数backtrack(n, output, res, first + 1);// 回退,需要吧位置交换回来Collections.swap(output, first, i);}}
}

复杂度

  • 时间复杂度:O(n*n!),其中 n 为数组的长度
  • 空间复杂度:O(n)
http://www.yayakq.cn/news/812788/

相关文章:

  • 网站建设借鉴一个网站的作用是什么
  • 网站建设方案如何讲解微商城app开发
  • 智慧团登录官方网站网页设计logo素材
  • 网站建设运营预算quark搜索引擎入口
  • 成都网站开发建设公司辽宁建设工程信息网怎么入库
  • 贵阳做网站好的公司有哪些王串场街网站建设公司
  • 榆林华科网站建设网站投稿源码
  • vps做网站空间wordpress支付宝支付宝
  • 网站开发需要学什么网站方案 模板
  • 福州官网建站厂计算机专业培训机构有哪些
  • 网站建设合伙合同优化网站制作公司好吗
  • 沈阳市浑南区城乡建设局网站辽宁专业模板网站建设公司
  • 做一个公司网站大概要多少钱怎么制作海报图片
  • 建设营销型网站公司湖南seo推广服务
  • 网站优化怎么弄传统营销
  • 临沂手机网站信息推广技术公司电话号码网站怎么放到服务器上
  • 如何投诉做网站的公司设计教程网站有哪些
  • 门户网站建设摘要windows优化大师是电脑自带的吗
  • 搭建网站有什么用门户网站app
  • 甘肃省城乡建设局网站wordpress的windows
  • 设计logo网站免费横屏纯色杭州制作网站的公司
  • 类似pinterest的网站要实现对网站中的所有内容进行搜索代码应该怎么写
  • 马鞍山建设银行网站网站建设公司响应式网站模板
  • 大连网站制作-中国互联住房和城乡建设部网站无在建
  • 茂名网站建设找个做游戏的视频网站好
  • thinkphp 网站源码wordpress后台菜单添加设置按钮
  • 传统网站建设团队浙江温州城乡建设网站
  • 比较好网站设计公司重庆做网络推广的公司
  • wordpress 作者列表seo网站监测
  • 专业的手机网站建设wordpress手机网站