问题

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3921 访问。

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""。

输入: ["flower","flow","flight"]

输出: "fl"

输入: ["dog","racecar","car"]

输出: ""

解释: 输入不存在公共前缀。

说明:所有输入只包含小写字母 a-z 。


Write a function to find the longest common prefix string amongst an array of strings.

If there is no common prefix, return an empty string "".

Input: ["flower","flow","flight"]

Output: "fl"

Input: ["dog","racecar","car"]

Output: ""

Explanation: There is no common prefix among the input strings.

Note:All given inputs are in lowercase letters a-z.


示例

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3921 访问。

public class Program {

    public static void Main(string[] args) {
var strs = new string[] { "flower", "flow", "flight" }; var res = LongestCommonPrefix(strs);
Console.WriteLine(res); Console.ReadKey();
} private static string LongestCommonPrefix(string[] strs) {
if(strs.Length == 0) return "";
if(strs.Length == 1) return strs[0];
var min = int.MaxValue;
foreach(var item in strs) {
if(item.Length < min) min = item.Length;
}
var index = -1;
for(var i = 0; i < min; i++) {
for(var j = 1; j < strs.Length; j++) {
if(strs[j][i] != strs[0][i]) return strs[0].Substring(0, i);
else {
index = i;
}
}
}
return strs[0].Substring(0, index + 1);
} }

以上给出1种算法实现,以下是这个案例的输出结果:

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/3921 访问。

fl

分析:

设数组的长度为 n,单词的最大长度为 m,那么显而易见,以上算法的时间复杂度为:  。

最新文章

  1. mvc AddImplicitRequiredAttributeForValueTypes
  2. Java基础-接口中国特色社会主义的体制中有这样的现象:地方省政府要坚持党的领导和按 照国务院的指示进行安全生产。请编写一个java应用程序描述上述的体制现象。 要求如下: (1)该应用程序中有一个“党中央”接口:CentralPartyCommittee,该接口中 有个“坚持党的领导”方法:void partyLeader() (2)该应用程序中有一个“国务院”抽象类:StateCouncil,
  3. Quartz.NET---任务调度框架
  4. dubbo服务治理框架设计
  5. 跨站点端口攻击 – XSPA(SSPA)
  6. ***PHP preg_match正则表达式的使用
  7. MyEclipse — Maven+Spring+Struts+Hibernate 整合 [学习笔记-3]
  8. C++向main函数传递参数的方法(实例已上传至github)
  9. java.lang.InstantiationError: sun.net.ftp.FtpClient
  10. [转]javascript函数定义表达式和函数声明的区别
  11. (转)yum 和 apt-get 用法及区别
  12. 在O(1)时间内删除单链表结点
  13. nginx+mysql+php
  14. 使用 Node.js 做 Function Test
  15. Fullcalendar改版后发布到IIS或者tomcat里面前端加载数据不显示的问题
  16. 关于在虚拟机上安装ubuntu输入不了中文的问题
  17. 快速做ssh免密钥登陆
  18. spring 自带框架及可替换框架
  19. Linux学习之CentOS(四)----Linux各目录的介绍
  20. fuzhou 1683 纪念SlingShot ***

热门文章

  1. Illegal instant due to time zone offset transition (Asia/Shanghai)_夏令时问题
  2. Maven如何利用父工程对版本进行统一管理
  3. 【软件安装】CentOS7安装MariaDb(mysql_替代品安装)
  4. C++语法小记---异常处理
  5. 【几何+模拟】二次元变换 计蒜客 - T3213
  6. 题解 CF613D 【Kingdom and its Cities】
  7. CMD运行JAVA出现“错误:编码GBK的不可映射字符”
  8. laravel开发调试工具laravel-debugbar的安装
  9. MyBatis动态插入的实现
  10. LQB2013A04倒置的标签