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

【算法笔记】LCR 086. 分割回文串

在这里插入图片描述
基本思想是使用回溯法,回溯法都可以将问题划分为一个解空间树:假设字符串s为"aab",那么我们可以使用深度优先搜索去构建解空间树:
在这里插入图片描述
dfs遍历出来的第一个序列是[a, a, b],显然该序列都是回文子串,接着回溯,遍历下一个序列,为[a, ab],不是回文子串,去除…如此往下遍历,将符合要求的序列加入到结果集res中,直到遍历整个解空间树

此题的重要思想有两个:
Java中的List变量存储的是List的地址,而非List本身,因此可以构建一个path列表,用于存储当前已经遍历的序列,当dfs向下遍历的时候则将新遍历的字符串加入path中;当向上回溯的时候,可以将path中的最后一个元素remove掉,从而恢复到上一个遍历状态

class Solution {public List<String> path = new ArrayList<>();public List<List<String>> result = new ArrayList();public void f(String str, int start){if (start >= str.length()){// 防止深复制导致的将List地址存入result,需要新建Listresult.add(new ArrayList<>(path));}for (int i = start; i < str.length(); i++) {if (isPalindrome(str, start, i)){path.add(str.substring(start, i+1));}elsecontinue;f(str, i+1);path.remove(path.size()-1); // 回溯}}public boolean isPalindrome(String s,int start,int end){//start从左到右,end从右到左,判断前后是否一致for(int i=start,j=end;i<j;i++,j--){if(s.charAt(i)!=s.charAt(j)){return false;}}return true;}public String[][] partition(String s) {f(s, 0);int rows = result.size();String[][] ret = new String[rows][];for (int i = 0; i < rows; ++i) {int cols = result.get(i).size();ret[i] = new String[cols];for (int j = 0; j < cols; ++j) {ret[i][j] = result.get(i).get(j);}}return ret;}
}
http://www.lryc.cn/news/188532.html

相关文章:

  • centos 安装svn
  • Java中的类加载器双亲委派模型机制
  • [spring] spring jpa - hibernate 名词解释配置
  • java判断字符串是否为时间格式
  • 【Java】什么是API
  • Hazelcast系列(三):hazelcast集成(服务器/客户端)
  • vscode 配置默认shell
  • 品牌低价的形式有哪些
  • SPA项目之主页面--数据表格的增删改查
  • Adobe Premiere Pro:掌控视频剪辑的魔法之手,让你的创作腾飞!
  • ES知识点全面整理
  • 【电商API封装接口】电商百万商品资源一键导入,助力企业流量变现
  • bootz启动 Linux内核过程中涉及的全局变量images
  • Vuex的使用,详细易懂
  • 基于多线程的Reactor模式的 回声服务器 EchoServer
  • 《TWS蓝牙耳机通信原理与接口技术》
  • 敏捷开发使用
  • cdsn目录处理:```,```# 目录校正
  • 前端TypeScript学习day03-TS高级类型
  • LeetCode-101-对称二叉树
  • 9-AJAX-上-原理详解
  • Python3操作Redis最新版|CRUD基本操作(保姆级)
  • 微信又被吐槽了,委屈啊
  • 刷题笔记27——并查集
  • Python 模拟类属性
  • 面试算法24:反转链表
  • 【论文阅读】面向抽取和理解基于Transformer的自动作文评分模型的隐式评价标准(实验结果部分)
  • VueRouter与expres/koa中间件的关联
  • 二十、SpringCloud Alibaba Seata处理分布式事务
  • 标准误与聚类稳健标准误的理解