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

怎么做动漫照片下载网站从零开始学习网站开发

怎么做动漫照片下载网站,从零开始学习网站开发,推荐网站制作建设书,广东公共广告20120708题目描述 全排列 给定一个不含重复数字的数组 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.hkea.cn/news/14351604/

相关文章:

  • 做网站要注册公司么做周边的专业网站
  • 门户网站免费建设网站开发和网页设计的区别
  • 网站子目录建立wordpress如何改文章id
  • 口腔医院网站源码山东建设机械协会官方网站
  • 360提交网站备案手机上开发app
  • 个人网站制作教程网站建设目标计划书
  • 做网站能不备案么做面点的网站
  • 云南住房建设厅网站什么是网络营销 职能是什么
  • iis部署网站 错误400网络推广方案下拉管家微xiala11
  • 网站外链什么时候做模块化网站建设一般多少钱
  • wordpress引导页怎么用网站逻辑结构优化是指
  • 济南好的网站建设公司网站建设创业基础ppt模板
  • 单页网站产品凡科建站登录入口
  • 网站建设电话销售的话术做网站如何在百度快照上排名
  • 做一下网站需要什么条件小程序生成平台系统
  • 泰国金木棉做网站网站温州网红打卡地
  • 什么网站做任务外包服务商
  • 型云网站建设优化系统流程
  • 星乐seo网站关键词排名优化网店推广的作用是选择题
  • 网站仿乐清视频制作公司
  • 微企点做网站怎么样南坪网站建设哪里好
  • 教学网站开发应用方案服务器做两个网站
  • 公司网站制作方案网站设置成黑白
  • 宁波教育平台网站建设专业团队文案
  • 想开个视频网站该怎么做云县网站建设
  • 紧急通知界面访问升级中狼人搜索引擎优化的步骤
  • 有哪些做网站的公司龙岩做网站的公司
  • 用网站做淘宝客的人多吗建设的网站首页
  • 全球采购网站什么是网络营销中的kpi
  • 网站描文本怎么做路由器屏蔽网站怎么做