编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 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/problems/longest-common-prefix
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
char * longestCommonPrefix(char ** strs, int strsSize){
//int flag = 0;
char *str = strs[0];//利用第一个来判断//因为strs[0]是常量字符串 不能被修改
int i,j;
if(strsSize == 0) return "";
for(i = 1; i<strsSize;i++){
j = 0;
while(str[j]&&strs[i][j]&&str[j]==strs[i][j])j++;//避免数组溢出并判断下一个元素是否相同
str[j] ='\0';//字符串结束符只输出前面对应相同的
}
return str;
}
该代码我认为是最简洁的 当然你如果不太理解 while循环里面的“避免数组元素益处”
你可以提前写一个判断 那个字符串最短 然后以那个最短的字符串为标准
加油铁汁~