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

网站首页排名突然没了教你免费申请个人网站

网站首页排名突然没了,教你免费申请个人网站,公司做网站要多久,网站在线客服公众号怎么做1.问题描述 给定一个不含重复数字的数组 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] 输出&#xf…

1.问题描述

        给定一个不含重复数字的数组 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 中的所有整数 互不相同

        难度等级

                中等

        题目链接

                全排列

2.解题思路

        这道题要求我们返回所有可能的全排列,每一个数都有可能在每一个位置出现,这里我们要用到回溯的思想。

        在解题之前,我们要先来定义一些变量,我们的一个排列,可以用一个List集合来表示,我们可以用一个辅助的List集合来寻找所有的全排列,并定义一个用来存储最终所有全排列的List数组(data),接着,我们还需要一个标识数组,来标识nums中的哪些数已经在当前排列中出现过了,防止出现同一个nums[i],在一个排列中排了两次。

        List<List<Integer>> data = new ArrayList<>();boolean[] used = new boolean[nums.length];

        这道题我们可以编写一个递归+回溯的方法来找到所有的排列。

        递归的结束条件是当辅助List的个数等于nums数组的个数时,说明所有的数都已经拿出来进行排列了,已经得到一个新的排列,这时,创建一个新的List将辅助数组的元素存入新的List中,再将List存入最终用来存储所有全排列的List集合中,然后直接返回即可。

        //如果list的大小 = nums的个数,说明得到一个排列if(list.size() == nums.length){//添加新的排列data.add(new ArrayList<>(list));return;}

        正常的递归逻辑也很简单,用一个for循环对nums数组进行遍历,先判断当前的数是否已经在辅助List排列了,如果已经在List中排列,则跳过这一个数。

        //遍历nums数组,将还没排列的数字取出来进行排序for(int i = 0;i < nums.length;i++){//已经被用过的数,直接跳过if(used[i] == true){continue;}......}

        如果还没有在参与排列,则将标记改为true并添加到辅助List中,参与排列,接着递归调用当前方法继续进行查找。找到包含当前子排列的所有排列之后,我们还需要对当前的排列进行回溯,将标记重新改回false,并将当前对应的这个数从辅助list中取出,防止对后面的排列造成影响。

        //遍历nums数组,将还没排列的数字取出来进行排序for(int i = 0;i < nums.length;i++){......//标记为已使用used[i] = true;//添加到当前的排列中list.add(nums[i]);//递归backtrack(data,list,nums,used);//回溯list.remove(list.size()-1);used[i] = false;}

        当递归方法完全执行完成之后,直接将用来存储全排列的List集合(data)返回即可。

        backtrack(data,new ArrayList<Integer>(),nums,used);return data;

3.代码展示

class Solution {public List<List<Integer>> permute(int[] nums) {List<List<Integer>> data = new ArrayList<>();boolean[] used = new boolean[nums.length];backtrack(data,new ArrayList<Integer>(),nums,used);return data;}public void backtrack(List<List<Integer>> data,List<Integer> list,int[] nums,boolean[] used){//如果list的大小 = nums的个数,说明得到一个排列if(list.size() == nums.length){//添加新的排列data.add(new ArrayList<>(list));return;}//遍历nums数组,将还没排列的数字取出来进行排序for(int i = 0;i < nums.length;i++){//已经被用过的数,直接跳过if(used[i] == true){continue;}//标记为已使用used[i] = true;//添加到当前的排列中list.add(nums[i]);//递归backtrack(data,list,nums,used);//回溯list.remove(list.size()-1);used[i] = false;}}
}

4.总结

        这道题没什么太大的难度,采用回溯+递归的方法穷尽所有的排列可能,让每一个数在每一个位置都出现一次。好了,这道题没啥好啰嗦的,祝大家刷题愉快,早日上岸!

http://www.dinnco.com/news/15848.html

相关文章:

  • 从事网站建设seo文章排名优化
  • 河南百度推广电话郑州seo招聘
  • wordpress插件统计佛山seo代理计费
  • 是否有可能一个人完成网站开发培训心得模板
  • wordpress网站被拒登个人引流推广怎么做
  • 免费网站源码html分类达人介绍
  • 深圳家装网站建设多少钱百度推广找谁
  • flash可以做网站吗实时疫情最新消息数据
  • 想注册一个做网站的公司好长沙谷歌优化
  • 如何建造网站专业竞价托管哪家好
  • 安装师傅最好的接单平台上海网络seo公司
  • 哈尔滨网站制作哪家好薇关注公众号推广2元一个
  • 移动网站建设的前景上海网上推广
  • 视频 主题 wordpress太原seo全网营销
  • 用模板建商场购物网站抖音视频排名优化
  • 网站的互动功能百度网站网址是多少
  • 建设银行app下载常用的seo工具的是有哪些
  • 网站的风格设计有哪些百度的官方网站
  • 国内做的比较好的跨境电商网站seo营销推广服务公司
  • 茶网站开发的意义目的长沙靠谱seo优化费用
  • 视频拍摄appseo策略什么意思
  • 免费建设网站设计页面百度推广登录首页
  • 亚洲精华国产精华液的护肤功效重庆网站seo好不好
  • 做任务免费得晋江币网站怎样才能在百度上发布信息
  • 武汉网站建设电话网络代理app
  • 网站管理员怎样管理员权限设置专业推广公司
  • 网站开发专业社会实践调研报告网络营销平台有哪些?
  • Python电影网站开发百度云官方网站
  • wordpress安装没有选择语言seo运营招聘
  • 织梦做的网站怎么上传视频教程中国今天刚刚发生的新闻