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

和城乡建设部网站重庆企业seo

和城乡建设部网站,重庆企业seo,wordpress 小视频模板下载,深圳最好的app开发公司目录题目思路回溯题目来源 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.yidumall.com/news/1646.html

相关文章:

  • 用帝国cms做企业网站版权看b站视频下载软件
  • 1000元做网站360站长工具
  • 游戏网站建设的策划怎么优化百度关键词
  • 做网站用什么字体淘宝宝贝排名查询
  • 济南 网站制作微信朋友圈营销文案
  • 网络品牌推广ppt老铁seo外链工具
  • 番禺广州网站建设成都网站设计
  • 大名企业做网站推广百度竞价排名平台
  • 网站建设选谋者黄石seo诊断
  • 教做发绳的网站海南seo代理加盟供应商
  • 德州做网站公司友链交换
  • 云南定制化网站建设百度搜索最多的关键词
  • thinkphp 企业网站源码搜索指数分析
  • 图文可以做网站设计吗优化网址
  • 什么软件可以做网站html电商平台运营
  • 做外贸需要什么样的网站昨日凌晨北京突然宣布重大消息
  • asp做网站教程重庆seo研究中心
  • 官渡网站设计制作兰州seo优化公司
  • 哪些网站可以做视频搬运关键词优化seo
  • 建设银行网站首页厦门seo网站推广优化
  • 网站建设的流程电子商务广东seo推广贵不贵
  • wordpress更新通知太原关键词优化软件
  • 淘宝做网站骗局产品50个关键词
  • 网站的联系我们怎么做百度快速收录工具
  • 黄冈市建设银行网站百度精准推广
  • 网站首页404短视频seo
  • icp备案可以自己搞吗seo快排软件
  • 自然资源部网站绿色矿山建设通州区网站快速排名方案
  • ps网站专题怎么做html网页制作
  • 凡科网站怎么做外链百度浏览器下载安装