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

【hot100-java】【分割回文串】

回溯篇

 

class Solution {//ret是需要返回的结果//path是回溯过程中的记录private final List<List<String>> ret=new ArrayList<>();private final List<String> path = new ArrayList<>();private String s;public List<List<String>> partition(String s) {this.s=s;dfs(0,0);return ret;}//start表示这段回文子串的开始位置private void dfs(int i,int start){//结束的时候将path赋给retif (i==s.length()){ret.add(new ArrayList<>(path));return;}//1.不选i和i+1之间的逗号(i=n-1时一定需要选)if(i<s.length()-1){dfs(i+1,start);}//2.选i和i+1之间的逗号(s[i]作为子串最后一个字符)if (isPalindrome(start,i)){path.add(s.substring(start,i+1));//下一个子串从i+1开始dfs(i+1,i+1);//恢复现场path.remove(path.size()-1);}}private boolean isPalindrome(int left,int right){while(left<right){if(s.charAt(left++)!=s.charAt(right--)){return false;}}return true;}
}


http://www.mrgr.cn/news/42933.html

相关文章:

  • AVL树的实现
  • 英语不好可以学编程吗?
  • SVG 简介
  • C语言 | Leetcode C语言题解之第457题环形数组是否存在循环
  • 云原生(四十六) | MySQL软件安装部署
  • C++ | Leetcode C++题解之第457题环形数组是否存在循环
  • C#串口温度读取
  • Java | Leetcode Java题解之第457题环形数组是否存在循环
  • 【设计模式】软件设计原则——接口隔离迪米特
  • CSRF 漏洞 - 学习手册
  • Java | Leetcode Java题解之第456题132模式
  • C语言高阶【2】--动态内存管理【2】--柔性数组(这是个全新的知识点,不想了解一下吗?)
  • C++入门基础知识99——【关于C++ 成员运算符】
  • Pikachu-Unsafe Fileupload-服务端check
  • etcd 快速入门
  • 【有啥问啥】SE(Squeeze-and-Excitation)架构详解
  • CUDA与TensorRT学习六:模型部署-CNN、模型部署-YOLOv8检测器、部署BEVFusion模型
  • vue-scrollto实现页面组件锚点定位
  • 最新版的dubbo服务调用(用nacos做注册中心用)
  • 【pytorch】张量求导