内容简介:2019-6-23 星期天 开始吧
2019-6-23 星期天 开始吧
上 一 题 链 接 Leetcode基础刷题之 PHP 解析(7. Reverse Integer)
题 目 描 述
这是一道字符串匹配的题,让我们求公共字符串前缀。
题 目 分 析
对于这一类题目,肯定都需要遍历对比一下,先来一种常规的思路,因为只要给定数组中元素当前位置有一个不同,那么公共字符串前缀就是从0截取到当前位置的上一个位置。所以我先随便拿出一个参照点(数组第一个元素),第一层遍历元素中的值,嵌套循环中遍历数组之后的元素,然后进行对比判断。最后得出结果。
/** * @param String[] $strs * @return String */ function longestCommonPrefix($strs) { if(empty($strs)) return ""; for($i=0;$i<strlen($strs[0]);$i++){ $temp=$strs[0][$i]; for($j=1;$j<count($strs);$j++){ if($i==strlen($strs[$j]) || $strs[$j][$i] != $temp){ $strs[0]=substr($strs[0],0,$i); } } } return $strs[0]; }
换一种思路
我们可以使用分而治之的思想啊。每次把数组中的元素分为两个部分,前(左)半部分和后(右)半部分,每次求出半个部分的字符串公共前缀,然后比较两个部分的公共前缀,最后得出整体的公共字符串前缀。这里求数组的中位数可以有三个方法,第一种并不推荐,因为当数值过大时可能会爆表。
/** * @param String[] $strs * @return String */ function longestCommonPrefix($strs) { if(empty($strs)) return ""; return $this->longCommon($strs,0,count($strs)-1); } function longCommon($strs,$l,$r) { if($l==$r) return $strs[$l]; else{ $mid = $l+(($r-$l)>>1) ; $left=$this->longCommon($strs,$l,$mid); $right=$this->longCommon($strs,$mid+1,$r); return $this->commonPrefix($left,$right); } } function commonPrefix($left,$right) { $min=min(strlen($left),strlen($right)); for($i=0;$i<$min;$i++){ if($left[$i] != $right[$i]){ return substr($left,0,$i); } } return substr($left,0,$min); }
Github整理地址 : https://github.com/wuqinqiang/leetcode-php
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Apache Flink 零基础入门(一):基础概念解析
- Apache Flink 零基础入门(一):基础概念解析
- JStorm 源码解析:基础线程模型
- React Hooks 解析(上):基础
- TypeScript基础入门之模块解析(一)
- TypeScript基础入门之模块解析(二)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深度探索C++对象模型(影印版)
Stanley B. Lippman / 中国电力出版社 / 2003-8-1 / 42.00
本书重点介绍了C++面向对象程序设计的底层机制,包括结构式语意、暂时性对象的生成、封装、继承和虚拟——虚拟函数和虚拟继承。书中向你表明:理解底层实现模型,可以极大地提高你的编码效率。Lippman澄清了那些关于C++系统开销与复杂性的各种错误信息和猜测,指出了其中某些成本和利益交换确实存在。他在书中详述了各种实现模型,指出了它们的发展方向以及促使其发展的根本原因。本书涵盖了C++对象模型的语意暗示......一起来看看 《深度探索C++对象模型(影印版)》 这本书的介绍吧!