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

wordpress站点设置使用时间论坛申请网站备案前置审批

wordpress站点设置使用时间,论坛申请网站备案前置审批,外贸网站seo博客,中国国内最新新闻字符串的排列_牛客题霸_牛客网【牛客题霸】收集各企业高频校招笔面试题目,配有官方题解,在线进行百度阿里腾讯网易等互联网名企笔试面试模拟考试练习,和牛人一起讨论经典试题,全面提升你的技术能力https://www.nowcoder.com/practice/fe6b651b66ae47d7ac…

字符串的排列_牛客题霸_牛客网【牛客题霸】收集各企业高频校招笔面试题目,配有官方题解,在线进行百度阿里腾讯网易等互联网名企笔试面试模拟考试练习,和牛人一起讨论经典试题,全面提升你的技术能力icon-default.png?t=N176https://www.nowcoder.com/practice/fe6b651b66ae47d7acce78ffdd9a96c7

描述

输入一个长度为 n 字符串,打印出该字符串中字符的所有排列,你可以以任意顺序返回这个字符串数组。

例如输入字符串ABC,则输出由字符A,B,C所能排列出来的所有字符串ABC,ACB,BAC,BCA,CBA和CAB。

class Solution {
public:set<string> res;    // 去重string temp;void dfs(string &s, vector<bool>& book, int index){if(index == s.size()){res.insert(temp);return;}for(int i = 0; i < s.size(); i++){if(book[i]){book[i] = false;temp+=s[i];dfs(s, book, index+1);temp.pop_back();book[i] = true;}}}vector<string> Permutation(string str) {vector<bool> book(str.size(), true);    // 标志位dfs(str, book, 0);vector<string> ress;for(auto &e : res){ress.push_back(e);}return ress;}
};

数据范围:n<10n<10
要求:空间复杂度 O(n!)O(n!),时间复杂度 O(n!)O(n!)

输入描述:

输入一个字符串,长度不超过10,字符只包括大小写字母。

示例1

输入:

"ab"

返回值:

["ab","ba"]

说明:

返回["ba","ab"]也是正确的         

示例2

输入:

"aab"

返回值:

["aab","aba","baa"]

示例3

输入:

"abc"

返回值:

["abc","acb","bac","bca","cab","cba"]

示例4

输入:

""

返回值:

[""]

思路:

都是求元素的全排列,字符串与数组没有区别,一个是数字全排列,一个是字符全排列,因此大致思路与有重复项数字的全排列类似,只是这道题输出顺序没有要求。但是为了便于去掉重复情况,我们还是应该参照数组全排列,优先按照字典序排序,因为排序后重复的字符就会相邻,后续递归找起来也很方便。

使用临时变量去组装一个排列的情况:每当我们选取一个字符以后,就确定了其位置,相当于对字符串中剩下的元素进行全排列添加在该元素后面,给剩余部分进行全排列就是一个子问题,因此可以使用递归

  • 终止条件: 临时字符串中选取了n个元素,已经形成了一种排列情况了,可以将其加入输出数组中。
  • 返回值: 每一层给上一层返回的就是本层级在临时字符串中添加的元素,递归到末尾的时候就能添加全部元素。
  • 本级任务: 每一级都需要选择一个元素加入到临时字符串末尾(遍历原字符串选择)。

递归过程也需要回溯,比如说对于字符串“abbc”,如果事先在临时字符串中加入了a,后续子问题只能是"bbc"的全排列接在a后面,对于b开头的分支达不到,因此也需要回溯:将临时字符串刚刚加入的字符去掉,同时vis修改为没有加入,这样才能正常进入别的分支。

具体做法:

  • step 1:先对字符串按照字典序排序,获取第一个排列情况。
  • step 2:准备一个空串暂存递归过程中组装的排列情况。使用额外的vis数组用于记录哪些位置的字符被加入了。
  • step 3:每次递归从头遍历字符串,获取字符加入:首先根据vis数组,已经加入的元素不能再次加入了;同时,如果当前的元素str[i]与同一层的前一个元素str[i-1]相同且str[i-1]已经用,也不需要将其纳入。
  • step 4:进入下一层递归前将vis数组当前位置标记为使用过。
  • step 5:回溯的时候需要修改vis数组当前位置标记,同时去掉刚刚加入字符串的元素,
  • step 6:临时字符串长度到达原串长度就是一种排列情况。

图示:

http://www.yayakq.cn/news/52253/

相关文章:

  • 网站导航栏全屏怎么做的加盟招商网站建设方案
  • 六安网站建设推广宿迁建设局网站拆除备案
  • 门户网站维护外贸网站怎么做seo
  • 水利建设相关网站天津seo管理平台
  • 北京网站设计培训做一个网站要多长时间
  • 福州公司网站研发项目管理系统
  • 哪个旅游网站做的比较好网站优化排名软件网
  • 墓园网站建设价格打开网站提示建设中
  • 网站建设的基本要素台州公司做网站
  • 天河做网站哪家强wordpress 自动生成文章
  • 长沙cms模板建站保定百度网站建设
  • 安装php和mysql网站wordpress转phpcms
  • 网站seo查询制作网站专业公司哪家好
  • 网页设计与网站开发教程运用搜索引擎营销的案例
  • 做网站需要备注号码能制作视频的软件
  • 百度网站收录更新html5 微信网站 源码
  • 三亚做网站找工作网站建设
  • 眼科医院网站建设方案wordpress文章内增加标题列表
  • 哪个在家做兼职网站比较好系统网站建设公司
  • 网站域名续费seo搜索引擎优化平台
  • 建设网站是要先建站在备案么中国建筑业协会
  • 企业官网怎么和别的网站做链接深圳注册公司代理
  • cms做网站不用后端广州模板建站平台
  • 手机英语网站射洪网站建设工作室
  • 章贡区网站建设北京软件开发公司官网
  • 网站数据库网络错误中山做网站好的公司
  • 深圳手机网站建设联系电话dede自定义网站地图
  • 艺术品展览公司网站建设达州建设机械网站
  • 响应式网站建设品牌全网天下网站上传wordpress
  • 个人响应式网站设计建立网站需要什么软件