当前位置: 首页 > 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.pierceye.com/news/100170/

相关文章:

  • 网站推广的软件六安网站制作哪里有
  • 大型门户网站模板wordpress有哪些小工具
  • 有flash的网站新闻资讯app制作公司
  • 网站和平台有什么区别黄页88怎么发信息质量高
  • 阿里建站价格小户型室内装修设计公司网站
  • 建设银行网站安全性分析网络推广服务平台
  • 大型购物网站建设福建微网站建设公司
  • 做网站软件j程序员找工作网站
  • 济南网站建设系统画册设计公司宣传册
  • 上海网站设计方案家纺网站建设
  • 衡水精品网站建设游戏广告推广平台
  • 响应式企业网站建设营销战略
  • wordpress离线浏览搜索引擎优化包括
  • 门户网站建设需要多少呼伦贝尔市住房和城乡建设局网站
  • 静海集团网站建设住房城乡建设网站
  • 个人备案挂企业网站网站开发公司照片
  • 网站建设课程体会国内最新新闻简短
  • 网站开发大概价格最常用的网页制作软件
  • 商务网站模块设计时前台基础设施建设免费网站建设空间
  • 青海省公路工程建设总公司网站饮料公司网站模板
  • 建设部网站刘赵云网页版邮箱
  • 免费扑克网站企业网站怎么搜索优化
  • 做网站导航的厦门网站建设制作多少钱
  • 怎样免费注册网站域名鹤城建设集团网站
  • 3合1网站建设价格网站建设论坛快速建站
  • 怎样做钓鱼网站上海网站关键词排名优化报价
  • 昆明专业网站设计公司电商类网站设计模板
  • 网站流量用完了重庆网站推广
  • 网站管理助手数据库网站在建设中无法访问
  • 网站标题格式建设网站南昌