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

广州网站设计公司兴田德润在哪儿注册公司取什么名字最佳

广州网站设计公司兴田德润在哪儿,注册公司取什么名字最佳,商务网站开发的基本流程,商城网站是免费开吗题目描述 全排列 给定一个不含重复数字的数组 nums #xff0c;返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1#xff1a; 输入#xff1a;nums [1,2,3] 输出#xff1a;[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]示例 2#xff1a; 输入…题目描述 全排列 给定一个不含重复数字的数组 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] 10nums 中的所有整数 互不相同 解法 回溯法 这个问题可以看作有 n 个排列成一行的空格我们需要从左往右依此填入题目给定的 n 个数每个数只能使用一次。那么很直接的可以想到一种穷举的算法即从左往右每一个位置都依此尝试填入一个数看能不能填完这 n 个空格在程序中我们可以用「回溯法」来模拟这个过程。 定义回溯函数 private void backtrack(int n, ListInteger output, ArrayListListInteger res, int first) { }first为当前要填的位置n位需要填的总位置数。 如果 firstn说明已经填完了 n 个位置注意下标从 0 开始找到了一个可行的解将 output 放入答案数组中递归结束。如果first n填第 first 个数的时候遍历题目给定的 n 个数如果这个数没有被标记过就尝试填入并将其标记继续尝试填下一个位置。假设我们已经填到第 first 个位置那么 nums 数组中 [0,first−1]是已填过的数的集合[first,n−1] 是待填的数的集合。 java代码 class Solution {/*** 回溯** param nums* return*/public ListListInteger permute(int[] nums) {ArrayListListInteger res new ArrayList();// nums不好交换位置使用ListListInteger output new ArrayListInteger();for (int num : nums) {output.add(num);}int n nums.length;// 使用回溯backtrack(n, output, res, 0);return res;}/*** 回溯算法* 如果 firstn说明已经填完了 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, ListInteger output, ArrayListListInteger 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.dnsts.com.cn/news/37999.html

相关文章:

  • 微信小程序在线玩十堰seo优化报价
  • 制作做动画的网站wordpress 存档
  • 农产品电商网站的建设需求建设快照网站
  • 雄县做网站企业网站如何推广
  • 易思企业网站管理南京网站微信建设
  • 做兼职什么网站好企业整站网站模板下载
  • 在税局网站上如何做进项税转出卸载本地wordpress
  • 搜狗网站seo做百度移动端网站软件下载
  • 如何选择武进网站建设网页qq登录不了怎么回事
  • 个人 网站 备案seo织梦网站建设步骤
  • 网站开发制作软件seo公司彼亿营销
  • 如何把网站加入白名单杭州做网站电话
  • php做的静态网站怎么加密主营商城网站建设
  • 如何做 网站映射电子商务网站建设与安全
  • 城乡与建设部网站wordpress 首页判断
  • 西安免费自助建站模板wordpress媒体优化
  • 泉州官方网站国家林业工程建设协会网站
  • 上海专业网站建设网大气网站欣赏
  • 最好的网站建设多少钱cms客户管理系统程序源码
  • 上海建站网站的企业网站提速
  • 做一个电商网站要多少钱西昌市住房与城乡建设厅网站
  • 杭州专业网站设计深圳企业网站制作哪个
  • 网站建设包含域名公司手机网站效果图
  • 怎么给喜欢的人做网站北京网上注册公司
  • 杭州赛虎网站建设电脑浏览器打不开怎么回事
  • vs2015做网站网站集群系统 如何做域名解析
  • php网站优点国外域名查询网站
  • 做招商网站win优化大师
  • 大连免费建站凡科快图 免费
  • 珠海做网站的公司有哪些r6300v2做网站