作者:快乐生活HAPPY-GO | 来源:互联网 | 2023-10-17 18:52
求数组中字符串的最长公共前缀(牛客网—牛客题霸算法篇—NC55)题目描述给你一个大小为n的字符串数组strs,其中包含n个字符串,编写一个函数来查找字符串数组中的最长公共前缀,返回
求数组中字符串的最长公共前缀
(牛客网—牛客题霸算法篇—NC55)
题目描述
给你一个大小为 n 的字符串数组 strs ,其中包含n个字符串 , 编写一个函数来查找字符串数组中的最长公共前缀,返回这个公共前缀。
思路
Java实现
将字符串数组看作一个二维空间,每一次从第一列开始。
确定所有字符子串中第一列字符。
逐层扫描后面每一列,遇到不同字符停止扫描。
涉及的函数:
subString()截取字串
length()字串长度
charAt()获取字符串某一位
代码实现
import java.util.*;
public class Solution {
/** * @param strs string字符串一维数组 * @return string字符串 */
public String longestCommonPrefix (String[] strs) {
// //纵向扫描
if(strs.length==0){
return "";
}
int n = strs[0].length();
//开始扫描
for(int i=0;i<n;i++){ //字符位数
char temp = strs[0].charAt(i);
for(int j=1;j<strs.length;j++){ //数组中第几个字符串
if(i<strs[j].length()){
if(temp!=strs[j].charAt(i)){
return strs[0].substring(0,i);
}
}else{
return strs[0].substring(0,i);
}
}
}
return strs[0];
}
}