题目:
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 1:
输入:strs = ["flower","flow","flight"]
输出:"fl"
示例 2:
输入:strs = ["dog","racecar","car"]
输出:""
解释:输入不存在公共前缀。
提示:
1 <= strs.length <= 200
0 <= strs[i].length <= 200
strs[i] 仅由小写英文字母组成
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-common-prefix
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路:
一、
1.首先判断特殊情况字符串长度为空,则直接返回空;
2.定义最长公共前缀的初始值res为str的第一个字符串;
3.遍历后面的字符串,依次与res相比较,两两进行比较更新最长公共前缀res的值,遍历结束后返回res值。
代码:
二、纵向扫描
从前往后遍历所有字符串的每一列,比较相同列上的字符是否相同,如果相同则继续对下一列进行比较,如果不相同则当前列不再属于公共前缀,当前列之前的部分为最长公共前缀。
代码:
小知识:
1.java中length和length()的区别:
在java中String类可以定义字符串变量和字符串数组,length()用于求String字符串对象的长度,是求String字符串对象中字符的个数,而length用
于求String字符串数组的长度,求字符串数组中有多少个字符串。
2.substring() 方法返回字符串的子字符串:
1 用法1:substring(int beginIndex, int endIndex):返回从起始位置到目标位置之间的字符串,但不包含目标位置 2 用法2:substring(int beginIndex):返回从起始位置到字符串末尾