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

和城乡建设部网站爱站网关键词密度查询

和城乡建设部网站,爱站网关键词密度查询,82端口做网站,化妆培训网站模板目录题目思路回溯题目来源 131. 分割回文串 题目思路 切割问题类似组合问题。 例如对于字符串abcdef: 组合问题:选取一个a之后,在bcdef中再去选取第二个,选取b之后在cdef中再选取第三个…。切割问题:切割一个a之后&…

目录

    • 题目思路
    • 回溯

题目来源
131. 分割回文串

题目思路

切割问题类似组合问题。
例如对于字符串abcdef:

  • 组合问题:选取一个a之后,在bcdef中再去选取第二个,选取b之后在cdef中再选取第三个…。
  • 切割问题:切割一个a之后,在bcdef中再去切割第二段,切割b之后在cdef中再切割第三段…。

抽象为一棵树形结构
在这里插入图片描述
递归用来纵向遍历,for循环用来横向遍历,切割线(就是图中的红线)切割到字符串的结尾位置,说明找到了一个切割方法。

回溯

  • 1.递归函数参数

全局变量数组path存放切割后回文的子串,二维数组result存放结果集。 (这两个参数可以放到函数参数里)
本题递归函数参数还需要startIndex,因为切割过的地方,不能重复切割,和组合问题也是保持一致的。

    ArrayList<List<String>> result = new ArrayList<>();ArrayList<String> path = new ArrayList<>();void backTracking(String s,int startIndex)
  • 2.递归函数终止条件
    在这里插入图片描述

从树形结构的图中可以看出:切割线切到了字符串最后面,说明找到了一种切割方法,此时就是本层递归的终止条件。
那么在代码里什么是切割线呢?
在处理组合问题的时候,递归参数需要传入startIndex,表示下一轮递归遍历的起始位置,这个startIndex就是切割线。
终止条件代码如下:

        if(startIndex >= s.length()){// 如果起始位置已经大于s的大小,说明已经找到了一组分割方案了result.add(new ArrayList(path));return;}
  • 3.单层搜索的逻辑

来看看在递归循环中如何截取子串呢?
在for (int i = startIndex; i < s.length(); i++)循环中,我们 定义了起始位置startIndex,那么 [startIndex, i] 就是要截取的子串。

首先判断这个子串是不是回文,如果是回文,就加入在path中,path用来记录切割过的回文子串。

        for(int i = startIndex;i<s.length();i++){//如果是回文子串,则记录if(isPalindrome(s,startIndex,i)){String str = s.substring(startIndex,i+1);path.add(str);}else{continue;}//起始位置后移,保证不重复backTracking(s,i+1);path.remove(path.size()-1);}

注意切割过的位置,不能重复切割,所以,backtracking(s, i + 1); 传入下一层的起始位置为i + 1。

判断回文子串

可以使用双指针法,一个指针从前向后,一个指针从后向前,如果前后指针所指向的元素是相等的,就是回文字符串了。

    private boolean isPalindrome(String s,int start,int end){for(int i=start,j=end;i<j;i++,j--){if(s.charAt(i) != s.charAt(j)){return false;}}return true;}

整体代码

class Solution {ArrayList<List<String>> result = new ArrayList<>();ArrayList<String> path = new ArrayList<>();public List<List<String>> partition(String s) {if(s == null || s.length() < 1){return result;}backTracking(s,0);return result;}public void backTracking(String s,int startIndex){// 如果起始位置已经大于s的大小,说明已经找到了一组分割方案了if(startIndex >= s.length()){result.add(new ArrayList(path));return;}for(int i = startIndex;i<s.length();i++){//如果是回文子串,则记录if(isPalindrome(s,startIndex,i)){String str = s.substring(startIndex,i+1);path.add(str);}else{continue;}//起始位置后移,保证不重复backTracking(s,i+1);path.remove(path.size()-1);}}private boolean isPalindrome(String s,int start,int end){for(int i=start,j=end;i<j;i++,j--){if(s.charAt(i) != s.charAt(j)){return false;}}return true;}
}

在这里插入图片描述

http://www.15wanjia.com/news/21469.html

相关文章:

  • 河南微网站建设公司站长工具网站查询
  • 怎么自己做APP网站最近刚发生的新闻
  • 共创福州网站建设宣传网页制作
  • 网站开发的基本知识色盲测试图免费测试
  • 乐居房产官方网站提高网站排名
  • 网站备案现场seo需要付费吗
  • 设计新闻发布网站模板百度免费发布信息网站
  • 建设网站怎么输入分子式网络营销方法有什么
  • 寻找网站建设员好的竞价账户托管外包
  • 做网站怎样收费的湛江百度网站快速排名
  • 网站图片标题背景怎样做的网站制作费用
  • 电子商务网站有那些功能百度搜索引擎营销案例
  • 嘉兴网站开发网络推广员是干什么的
  • 如何用万网做自己的网站百度搜索热度指数
  • 深圳企业网站建设定制开发服务友情链接2598
  • 什么网站可以做ppt搜索引擎的关键词优化
  • 顺德手机网站设计价位国际最新十大新闻事件
  • 口碑营销的前提及好处有哪些江西网络推广seo
  • 国产成年做视频网站爱站网关键词查询网站
  • 做虚拟网站要花多少钱百度官方推广
  • 制作企业网站的一般流程站长之家查询工具
  • 登封网站制作网站建设seo还可以做哪些推广
  • 移动公司营销网站设计网站设计与制作教程
  • 帝国cms调用网站地址长沙seo推广公司
  • 中山网站建设提升网页优化排名
  • 怎么样在网站做产品推广网络营销的真实案例分析
  • 网站做全景图微信群推广
  • 深圳国内网站设计公司加盟
  • 舆情监测工作要怎么做广州seo工程师
  • wordpress explodeseo关键词排名优化哪家好