【LeetCode】14. Longest Common Prefix 最长公共前缀问题
2016-03-14 21:31
417 查看
题目:
Write a function to find the longest common prefix string amongst an array of strings.
翻译:找到一个字符串数组的最长公共前缀。
例如:若给定字符串数组string[] strs为:
aabbccdd
aabbbbbcccccc
aab
aabbccd
则返回的最长公共前缀为:aab
基本思想:
1.strs为空(无字符串),或第一个字符串str[0]为空串,则返回空串;
2.若strs的大小为1,即只有一个字符串,则该字符串本身就是这个字符串数组本身的最长公共前缀;
3.若不满足以上两种情况,则依次比对第1个字符串和其他所有字符串的第1个字符、第2个字符、第3个字符...第i个字符...直到某个字符串长度小于i+1,或者第i个字符不匹配,则返回第1个字符串的前i个字符前缀为最长公共前缀;
4.若第一个字符串的所有字符均比对完毕,还未返回,则返回第1个字符串为最长公共前缀。
代码:
Write a function to find the longest common prefix string amongst an array of strings.
翻译:找到一个字符串数组的最长公共前缀。
例如:若给定字符串数组string[] strs为:
aabbccdd
aabbbbbcccccc
aab
aabbccd
则返回的最长公共前缀为:aab
基本思想:
1.strs为空(无字符串),或第一个字符串str[0]为空串,则返回空串;
2.若strs的大小为1,即只有一个字符串,则该字符串本身就是这个字符串数组本身的最长公共前缀;
3.若不满足以上两种情况,则依次比对第1个字符串和其他所有字符串的第1个字符、第2个字符、第3个字符...第i个字符...直到某个字符串长度小于i+1,或者第i个字符不匹配,则返回第1个字符串的前i个字符前缀为最长公共前缀;
4.若第一个字符串的所有字符均比对完毕,还未返回,则返回第1个字符串为最长公共前缀。
代码:
public class Solution { public string LongestCommonPrefix(string[] strs) { if(strs.Length==0||strs[0].Length==0) return string.Empty; if(strs.Length==1) return strs[0]; int i=0; while(i<strs[0].Length) { for(int j=1;j<strs.Length;j++) { if(strs[j].Length<i+1||strs[j][i]!=strs[0][i]) return strs[0].Substring(0,i); } i++; } return strs[0]; } }
相关文章推荐
- windows客户端开发--获取windows系统中文件的MIME
- 知识树UML部分建模 第二周作业
- 目前流行的源程序版本管理软件和项目管理软件都有哪些?各有什么优缺点?以及Github的注册过程
- 机器学习:序列模式挖掘算法
- Scala 匿名函数
- uva 11997——K Smallest Sums
- C++学习笔记第二周(极客班)
- SDUT 3509 51nod 1276
- WPF Image控件的绑定
- 设计模式-原型模式
- Activity周期、加载模式理解
- PS——书籍装帧
- Python自然语言处理 - 系列四
- JS基础回顾,小练习(DOM元素)
- 2016/3/14 开始自己的编程之路
- 把一元硬币换成1分,2分5分的硬币有几种不同的方法
- 网页
- bash shell的编程
- OpenMP中的常用函数
- 【1】-x86架构内核的配置和编译