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

塘沽做网站的公司传奇一条龙

塘沽做网站的公司,传奇一条龙,网站设计照着做 算侵权吗,湖南做网站 要上磐石网络分割回文串 力扣原题链接 问题描述 给定一个字符串 s#xff0c;请你将 s 分割成一些子串#xff0c;使每个子串都是回文串。返回 s 所有可能的分割方案。 示例 示例 1: 输入#xff1a;s “aab” 输出#xff1a;[[“a”,“a”,“b”],[“aa”,“b”]] 示例 2: 输…分割回文串 力扣原题链接 问题描述 给定一个字符串 s请你将 s 分割成一些子串使每个子串都是回文串。返回 s 所有可能的分割方案。 示例 示例 1: 输入s “aab” 输出[[“a”,“a”,“b”],[“aa”,“b”]] 示例 2: 输入s “a” 输出[[“a”]] 解题思路 这是一个典型的回溯算法问题。我们需要从字符串的开头开始逐步尝试切割出回文子串并将这些回文子串组合成分割方案。 回溯搜索 定义一个回溯函数 backtrack其参数包括当前处理的索引 start、当前的字符串 s 和当前的回文子串列表 path。结束条件 如果当前索引 start 等于字符串 s 的长度说明已经处理完了整个字符串将当前回文子串列表加入结果列表并返回。选择列表 从当前索引 start 开始的所有可能的回文子串。遍历选择 从当前索引 start 开始向后扫描字符串依次尝试切割出回文子串。判断回文 对于每个可能的切割点判断从当前索引 start 到该切割点是否构成回文子串。递归进入下一层 如果切割点构成回文子串则将该回文子串加入当前回文子串列表并递归调用回溯函数传入新的索引 i 1、新的字符串 s 和更新后的回文子串列表。撤销选择 回溯到上一层时将刚刚加入的回文子串从列表中删除继续尝试下一个切割点。 Java解题 垃圾版 import java.util.*;class Solution {ListListString res new ArrayList(); // 存储结果的列表public ListListString partition(String s) {ListString path new ArrayList(); // 存储当前回溯路径的列表backtrack(s, 0, path); // 调用回溯函数从索引 0 开始遍历字符串 sreturn res; // 返回结果列表}// 回溯函数public void backtrack(String s, int start, ListString path) {if (start s.length()) { // 如果起始索引达到了字符串的长度说明已经遍历完成res.add(new ArrayList(path)); // 将当前回溯路径添加到结果列表中return; // 返回结束当前回溯路径}for (int i start; i s.length(); i) { // 遍历字符串 s从当前起始索引开始String substr s.substring(start, i 1); // 获取当前子串if (isPalindrome(substr)) { // 如果子串为回文串path.add(substr); // 将回文子串添加到当前路径中backtrack(s, i 1, path); // 递归进入下一层从下一个字符开始遍历path.remove(path.size() - 1); // 回溯撤销选择将当前回文子串移出路径}}}// 判断字符串 s 是否为回文串public boolean isPalindrome(String s) {return s.equals(new StringBuilder(s).reverse().toString()); // 使用StringBuilder类的reverse方法判断是否为回文串} }优化版 判断回文串的方法更高效在这个版本中使用了双指针的方法来判断子串是否为回文串。相比于前一个版本中使用 StringBuilder 反转字符串再比较的方法双指针的方法只需要遍历一次字符串更加高效。 减少了不必要的字符串拷贝在判断回文串时这个版本直接使用了字符串的索引范围来进行判断而不是通过 substring 方法生成子串。这样可以避免创建新的字符串对象减少了内存消耗和时间开销。 class Solution {ListListString res new ArrayList();public ListListString partition(String s) {ListString path new ArrayList();backtrack(s, 0, path);return res;}public void backtrack(String s, int start, ListString path) {if (start s.length()) { // 结束条件res.add(new ArrayList(path));return;}for (int i start; i s.length(); i) {if (isPalindrome(s, start, i)) { // 判断回文path.add(s.substring(start, i 1)); // 做出选择backtrack(s, i 1, path); // 递归进入下一层path.remove(path.size() - 1); // 撤销选择}}}public boolean isPalindrome(String s, int start, int end) {while (start end) {if (s.charAt(start) ! s.charAt(end--)) {return false;}}return true;} }
http://www.zqtcl.cn/news/100170/

相关文章:

  • 做传奇网站怎么弄的南京微网站开发
  • 网站建设基础教程人教版网站域名选择的原则
  • u盘做网站网站建设公司公司介绍
  • 嘉兴网站排名优化报windows wordpress 轻量级
  • html5网站开发方案海珠网站建设公
  • 津做网站建筑网课平台
  • 佛山制作手机网站汕头网站定制
  • 网站域名解释怎么做济南集团网站建设
  • 网站怎么做咨询网站开发商
  • 建立网站的第一步网站的管理系统
  • 安远做网站做宣传册网站
  • 网站建设概况君隆网站建设
  • 富源县住房和城乡建设局网站备案信息 网站名
  • 做门窗的网站宁波附近的seo推广
  • 上海网站建设解决方案怎样设计网站
  • 龙华建站公司seo研究中心怎么样
  • 网站的大图标怎么做项目网站
  • 南京网站设计机构wap网站设计方案
  • 建站点怎么做网站wordpress 重写规则
  • 泰州做网站优化服装网站建设方案ppt
  • wordpress怎么设计网站微商城科技
  • 昆山营销型网站建设旅游网页制作模板教程
  • 企业网站开发时间淘客网站开发源代码
  • 传奇世界新开服网站html静态网页模板代码
  • 门户网站app开发网络服务提供者发现未成年通过网络发布
  • 编辑网站在线注册系统行业网站制作
  • 国外建设网站的软件西宁设计网站建设
  • 云服务器网站配置在线设计免费logo
  • 怎么在手机上做企业网站北京大学两学一做网站
  • 社区网站建设方案书服务型网站建设的主题