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

上海网上做鸭子的网站厦门网络营销推广

上海网上做鸭子的网站,厦门网络营销推广,浙江省建设职业注册中心网站,来个网站急急急2021年14. 最长公共前缀 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀,返回空字符串 “”。 示例 1: 输入:strs [“flower”,“flow”,“flight”] 输出:“fl” 示例 2: 输入:strs [“d…

14. 最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 “”。
示例 1:
输入:strs = [“flower”,“flow”,“flight”]
输出:“fl”
示例 2:
输入:strs = [“dog”,“racecar”,“car”]
输出:“”
解释:输入不存在公共前缀。
提示:
1 <= strs.length <= 200
0 <= strs[i].length <= 200
strs[i] 仅由小写英文字母组成

  • 最容易想到的思路就是先默认第一个字符串为结果 res,然后遍历剩下的字符串,不断根据 res 以及 str 的比较得到新的 res,这样就相当于比较了所有字符串,最终 res 就是公共前缀
  •   public String longestCommonPrefix(String[] strs) {if(strs.length == 0)return "";String res = strs[0];for(int i = 1; i < strs.length; i++){res = getPre(res, strs[i]);if("".equals(res))break;}return res;}public String getPre(String s1, String s2){int min = Math.min(s1.length(), s2.length());int i = 0;while(i < min && s1.charAt(i) == s2.charAt(i)){i++;}return s1.substring(0, i);}
    
  • 既然有横向的,那么纵向的也比较容易想到,取任意一个字符串为例,从第一位开始,比较所有字符串某一位是否等于该字符的这一位,需要注意的是不仅当遇到不同字符时需要返回,当某个字符串已经被比较完也应该返回
  •   public String longestCommonPrefix(String[] strs) {if(strs.length == 0)return "";for(int i = 0; i < strs[0].length(); i++){char c = strs[0].charAt(i);for(int j = 1; j < strs.length; j++){if(i == strs[j].length() || strs[j].charAt(i) != c){return strs[0].substring(0, i);}}}// 理论上来说返回什么都可以,因为上面的情况已经包含了比较完的情况// 但是 strs 只有一个字符串时就不会进入比较// 所以需要返回 strs[0]return strs[0];}
    
  • 分治:由于不管怎么样最终每个字符都会被比较,比如第一种解法就是不断更新两个字符串比较后的结果,那么其实分治也可以,不过同时比较两组字符串而已
  •   public String longestCommonPrefix(String[] strs) {if(strs.length == 0)return "";return longestCommonPrefix(strs, 0, strs.length - 1);}// 分治public String longestCommonPrefix(String[] strs, int start, int end) {if(start == end)return strs[start];int mid = start + (end - start) / 2;String left = longestCommonPrefix(strs, start, mid);String right = longestCommonPrefix(strs, mid + 1, end);return commonPrefix(left, right);}// 获取两个字符串的公共前缀public String commonPrefix(String lcpLeft, String lcpRight) {int minLength = Math.min(lcpLeft.length(), lcpRight.length());       for (int i = 0; i < minLength; i++) {if (lcpLeft.charAt(i) != lcpRight.charAt(i)) {return lcpLeft.substring(0, i);}}return lcpLeft.substring(0, minLength);}
    
  • 二分法:由于最终公共前缀的长度不会大于最短字符串长度 min ,那么可以在解法 2 的基础上,使用二分法,从 left = 0 ,right = min 开始,得到最终公共前缀的长度
  •   public String longestCommonPrefix(String[] strs) {if(strs.length == 0)return "";int min = Integer.MAX_VALUE;for (String str : strs) {min = Math.min(min, str.length());}int left = 0, right = min;while(left < right){int mid = left + (right - left + 1) / 2;if(isCommonPrefix(strs, mid))left = mid;else right = mid - 1;}return strs[0].substring(0, left);}// 判断 length 是否为公共前缀public boolean isCommonPrefix(String[] strs, int length) {    for (int i = 0; i < length; i++) {char c = strs[0].charAt(i);for(int j = 1; j < strs.length; j++){if(strs[j].charAt(i) != c)return false;}}return true;}
    
http://www.ds6.com.cn/news/92979.html

相关文章:

  • 网站建设公司怎么开网络视频营销平台
  • 上海网站建设 app开发专业网站优化排名
  • 做的网站修改编码网站推广途径和推广要点
  • 深圳电子网站开发最新百度新闻
  • h5怎么生成二维码淄博网站制作优化
  • 大团网站建设seo软件简单易排名稳定
  • 类似淘宝网站建设费用互联网营销模式有哪些
  • 河南省内 在哪个网站做商检表品牌宣传如何做
  • 网站建设社团活动宗旨微博推广有用吗
  • 做网站市场引流app推广软件
  • 科技广告公司网站建设石家庄网站seo
  • 幼儿园线性主题网络图设计刷seo快速排名
  • 番禺做网站公司百度推广优化师
  • 深圳的网站建设公司排名工具刷网站排刷排名软件
  • 怎样注册代理记账公司百度广告优化
  • 石家庄网站制作官网平台推广方式方法是什么
  • 网站建设 天猫 保证金网络营销概述ppt
  • 学校资源网站 建设一个具体网站的seo优化方案
  • 同企网站建设做网站杭州余杭区抖音seo质量高
  • dede企业网站青岛seo网站推广
  • 绿色国外网站什么是百度推广
  • 网站建设的好处2022年百度seo
  • 做网站需要前台和后台吗全国疫情高峰感染进度
  • WordPress商用收费吗关键词优化公司电话
  • 丰顺网站建设搜索引擎有哪些网站
  • 网站开发项目建设经验seo网站优化论文
  • 常德建设网站网站制作工具有哪些
  • 发布做网站需求qq群产品推广文案100字
  • 济南网站建设0531soso百度网站下拉排名
  • 做企业形象网站网络推广工作好吗