博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
G面经prepare: Chucked Palindrome
阅读量:4964 次
发布时间:2019-06-12

本文共 1326 字,大约阅读时间需要 4 分钟。

给定一个字符串,找出最多有多少个chunked palindrome,正常的palindrome是abccba, chunked palindrome的定义是:比如volvo, 可以把vo划分在一起,(vo) (l) (vo),那么它是个palindrome。求实现返回最大的chunk 数量。比如aaaaaa可以是(aaa)(aaa), 但是最大chunk数量应该是(a)(a)(a)(a)(a)(a)为6

这就是一个greedy的问题,从string的两边开始,用i和j记录当前scan到的位置,用prev_i和prev_j记录上一次找到chunk的i和j的位置的下一个字符。最后扫到中间判断一下有无多余的chunk。

时间复杂度为O(N^2), 内层string.equals 有O(N)复杂度

1 package ChunkedPalindrome; 2  3 public class Solution { 4     public int countChunk(String str) { 5         if (str==null || str.length()==0) return 0; 6         int sum = 0; 7         int l=0, r=str.length()-1; 8         int preL = l, preR = r; 9         while (l < r) {10             String left = str.substring(preL, l+1);11             String right = str.substring(r, preR+1);12             if (left.equals(right)) {13                 preL = l+1;14                 preR = r-1;15                 sum += 2;16             }17             l++;18             r--;19         }20         if (preL <= preR) sum+=1;21         return sum;22     }23     24 25     /**26      * @param args27      */28     public static void main(String[] args) {29         // TODO Auto-generated method stub30         Solution sol = new Solution();31         int res = sol.countChunk("aaaaaa");32         System.out.println(res);33     }34 35 }

 

转载于:https://www.cnblogs.com/EdwardLiu/p/5136947.html

你可能感兴趣的文章
笔记:git基本操作
查看>>
生成php所需要的APNS Service pem证书的步骤
查看>>
JavaWeb之JSON
查看>>
HOT SUMMER 每天都是不一样,积极的去感受生活 C#关闭IE相应的窗口 .
查看>>
windows平台上编译mongdb-cxx-driver
查看>>
optionMenu-普通菜单使用
查看>>
MVC3分页传2参
查看>>
2016-2017-2点集拓扑作业[本科生上课时]讲解视频
查看>>
appium(13)- server config
查看>>
IIS负载均衡-Application Request Route详解第六篇:使用失败请求跟踪规则来诊断ARR...
查看>>
管理信息系统 第三部分 作业
查看>>
[Leetcode Week13]Search a 2D Matrix
查看>>
查看端口占用cmd命令
查看>>
2019.01.17王苛震作业
查看>>
Halcon学习(八)文本操作
查看>>
清除浮动
查看>>
PayPal(贝宝)支付接口、文档、IPN
查看>>
ORACLE 10G R2_执行计划中cost cardinality bytes cpu_cost io_cost解释
查看>>
本地存储
查看>>
MP3的播放与停止
查看>>