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

网站翻译建设平台推广方式有哪些

网站翻译建设,平台推广方式有哪些,济宁百度竞价推广,搜索引擎营销特点是什么全排列 https://leetcode.cn/problems/permutations/ 描述 给定一个不含重复数字的数组 nums #xff0c;返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1 输入#xff1a;nums [1,2,3] 输出#xff1a;[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,…全排列 https://leetcode.cn/problems/permutations/ 描述 给定一个不含重复数字的数组 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 中的所有整数 互不相同 算法实现 1 回溯1: 基于数组 function permute(nums: number[]): number[][] {const res: number[][] [];// 回溯函数const backtrack (path: number[]) {// 满足当前条件if(path.length nums.length) {res.push(path);return;}// 遍历for(let i 0; i nums.length; i) {if(path.includes(nums[i])) continue;backtrack(path.concat(nums[i]));}}backtrack([]);return res; }时间复杂度O(n*n!) 假设输入数组的长度为 n遍历每个元素的时间复杂度为 O(n)对于每个元素都会进行递归调假设数组中有 n 个不同的元素那么对于每个元素都会有 n-1 个可能的选择然后对于每个选择又会有 n-2 个可能的选择以此类推因此递归的时间复杂度可以表示为 O(n!)。在每一层递归中都会进行一次包含操作includes其时间复杂度为 O(n)。综合考虑这段代码的时间复杂度为 O(n * n!)其中 n 表示输入数组的长度。需要注意的是这里的时间复杂度分析基于平均情况。在最坏情况下全排列的数量是 n!因此在最坏情况下时间复杂度为 O(n * n!)注意: n的阶乘公式: n! 1*2*3*...*(n-1)*n 空间复杂度O(n) 递归堆栈不是常量是线性增长的是递归的层数 2 回溯2: 基于交换 function permute(nums: number[]): number[][] {const res: number[][] [];const backtrack function(start: number) {if (start nums.length - 1) {res.push([...nums]);return;}for (let i: number start; i nums.length; i) {[nums[i], nums[start]] [nums[start], nums[i]]; // 交换backtrack(start 1); // 下一个数[nums[i], nums[start]] [nums[start], nums[i]]; // 交换撤销}}backtrack(0); // 从 0 开始return res; };这个问题可以看作有 n 个排列成一行的空格我们需要从左往右依此填入题目给定的 n 个数每个数只能使用一次那么很直接的可以想到一种穷举的算法即从左往右每一个位置都依此尝试填入一个数看能不能填完这 n 个空格在程序中我们可以用「回溯法」来模拟这个过程时间复杂度O(n*n!)其中 n 为序列的长度空间复杂度O(n) 回溯算法、递归和深度优先遍历之间的关系 它们通常在算法中一起使用因为回溯算法通常使用递归来实现并且常常涉及到深度优先遍历的思想。 回溯算法与递归 回溯算法是一种渐进式寻找并构建问题解决方案的策略。在回溯算法中通常通过递归的方式来尝试所有可能的情况。当找到一个可能的解决方案时它会继续探索下去如果发现不符合条件就会回溯到上一个状态尝试其他可能的情况。因此回溯算法通常使用递归来实现因为递归天然地适合于处理这种尝试所有可能情况的问题。 回溯算法与深度优先遍历(DFS) 回溯算法通常使用深度优先遍历的思想。在回溯算法中我们会尝试一条路走到底直到无法再继续下去然后回溯到上一个状态尝试其他的可能性。这与深度优先遍历的思想是一致的深度优先遍历也是尽可能深地搜索树的分支直到无法再继续为止然后回溯到上一个节点继续搜索其他分支 因此回溯算法通常使用递归来实现并且其思想与深度优先遍历密切相关。 在许多情况下回溯算法可以被视为一种特殊的深度优先遍历。
http://www.zqtcl.cn/news/566038/

相关文章:

  • 宜春网站开发网页编辑器安卓版
  • 网站建设外包兼职建设工程合同可以分为
  • 我国网络营销现状分析重庆网站seo营销模板
  • 深圳建站公司网站免费推广预期效果
  • html5 国外网站后台网站要做权限前端还是后台做
  • 免费建自己的网站网站标题 关键词 描述之间的关系
  • 提供响应式网站建设wordpress怎么做背景图片
  • 相亲网与做网站做网站的目的与意义
  • 做网站字体大小网站建设是属于虚拟产品吗
  • 网站的内链怎么做校园网建设网站特色
  • 优化网站标题企业的网站一般做哪些维护
  • 聊天网站备案南阳定制网站制作价格低
  • 广州镭拓科技网站建设公司长春招聘
  • 视频网站app怎么做跨境贸易电子商务服务平台
  • 丽水网站seo餐饮vi设计案例
  • 娄底网站建设报价山东省住房和建设厅注册中心网站
  • 公司网站建设工作重点网站建设吉金手指专业11
  • vue做前台网站怎么做钓鱼网站吗
  • 个人建设网站如何定位烟台h5网站开发
  • 广州网站定制多少钱html5游戏开发
  • 使用angularjs的网站域名怎么解析到服务器
  • 地方门户网站盈利模式宝塔 wordpress
  • 西安网站备案软件开发基础教程
  • 有服务器做网站软件系统开发怎样容易
  • 网站建设的公司有发展吗织梦婚纱网站模板
  • 淘宝销售书网站建设方案wordpress调用评论数据
  • 搭建网站需要什么软件苏州吴中区建设局工程网站
  • 长沙市网站推广公司wordpress 弹窗登录插件
  • 网站策划怎么做内容朔州网站建设公司
  • 宁波拾谷网站建设蚌埠网站建设中心