C#LeetCode刷题之#14-最长公共前缀(Longest Common Prefix)
问题
该文章的最新版本已迁移至个人博客【比特飞】,单击链接 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,那么显而易见,以上算法的时间复杂度为: 。
最新文章
- mvc AddImplicitRequiredAttributeForValueTypes
- Java基础-接口中国特色社会主义的体制中有这样的现象:地方省政府要坚持党的领导和按 照国务院的指示进行安全生产。请编写一个java应用程序描述上述的体制现象。 要求如下: (1)该应用程序中有一个“党中央”接口:CentralPartyCommittee,该接口中 有个“坚持党的领导”方法:void partyLeader() (2)该应用程序中有一个“国务院”抽象类:StateCouncil,
- Quartz.NET---任务调度框架
- dubbo服务治理框架设计
- 跨站点端口攻击 – XSPA(SSPA)
- ***PHP preg_match正则表达式的使用
- MyEclipse — Maven+Spring+Struts+Hibernate 整合 [学习笔记-3]
- C++向main函数传递参数的方法(实例已上传至github)
- java.lang.InstantiationError: sun.net.ftp.FtpClient
- [转]javascript函数定义表达式和函数声明的区别
- (转)yum 和 apt-get 用法及区别
- 在O(1)时间内删除单链表结点
- nginx+mysql+php
- 使用 Node.js 做 Function Test
- Fullcalendar改版后发布到IIS或者tomcat里面前端加载数据不显示的问题
- 关于在虚拟机上安装ubuntu输入不了中文的问题
- 快速做ssh免密钥登陆
- spring 自带框架及可替换框架
- Linux学习之CentOS(四)----Linux各目录的介绍
- fuzhou 1683 纪念SlingShot ***
热门文章
- Illegal instant due to time zone offset transition (Asia/Shanghai)_夏令时问题
- Maven如何利用父工程对版本进行统一管理
- 【软件安装】CentOS7安装MariaDb(mysql_替代品安装)
- C++语法小记---异常处理
- 【几何+模拟】二次元变换 计蒜客 - T3213
- 题解 CF613D 【Kingdom and its Cities】
- CMD运行JAVA出现“错误:编码GBK的不可映射字符”
- laravel开发调试工具laravel-debugbar的安装
- MyBatis动态插入的实现
- LQB2013A04倒置的标签