14.最长公共前缀-力扣(LeetCode)

题目:

解题思路:

解决本题的关键点是确定扫描的方式,大体上有两种方式:横向扫描和纵向扫描。

1、横向扫描:首先比较第一个字符串和第二个字符串,记录二者的公共前缀,然后用当前公共前缀与下一个字符串再次比较得出新的公共前缀,重复过程,直到所有字符串完成比较,或者中间过程中得到的公共前缀为空串时停止并返回。

2、纵向扫描:共进行k轮比较(k大小不超过第一个字符串的长度,因为最长公共前缀不可能比传入的字符串还长)。在每一轮比较中,对所有字符串的第k位进行比较,如果出现不同,证明当前比较位前面的字符串为最长公共前缀,对最长公共前缀进行返回,否则比较下一轮。完成所有轮比较后,仍要进行一次返回,此时每个字符串及最长公共前缀都相同。

在函数中,采用纵向扫描。动态开辟了空间用作返回最长公共前缀,这块空间的大小没有去求字符串的长度来决定,根据提示中的信息,取了一个长度最大值200,能够满足所有情况。这里利用将返回地址中提前存入第一个字符串、过程中判断并修改'\0'来实现对最长公共前缀的存储。

代码:

cpp 复制代码
char *longestCommonPrefix(char **strs,int strsSize)
{
    if(strsSize == 0){return "";}
    char *returnStr = (char *)malloc(200);
    strcpy(returnStr,strs[0]);
    for(int j = 0; j < strlen(strs[0]); j++)
    {
        for(int i = 1; i < strsSize; i++)
            {
                if(returnStr[j] != strs[i][j])
                {
                    returnStr[j] = '\0';
                    return returnStr;
                }
            }
    }
    return returnStr;
}
相关推荐
Joyner201811 小时前
python-leetcode-从中序与后序遍历序列构造二叉树
算法·leetcode·职场和发展
因兹菜11 小时前
[LeetCode]day9 203.移除链表元素
算法·leetcode·链表
LNsupermali11 小时前
力扣257. 二叉树的所有路径(遍历思想解决)
算法·leetcode·职场和发展
雾月5511 小时前
LeetCode LCR180文件组合
算法·leetcode·职场和发展
萌の鱼11 小时前
leetcode 2080. 区间内查询数字的频率
数据结构·c++·算法·leetcode
Tisfy11 小时前
LeetCode 0541.反转字符串 II:模拟
算法·leetcode·字符串·题解
labmem113 小时前
Leetcode:541
算法·leetcode·职场和发展
圆圆滚滚小企鹅。14 小时前
刷题记录 HOT100回溯算法-6:79. 单词搜索
笔记·python·算法·leetcode
钓一朵雪16 小时前
【Leetcode刷题记录】45. 跳跃游戏 II--贪心算法
leetcode·贪心算法
sjsjs1117 小时前
【数据结构-前缀树】力扣208. 实现 Trie (前缀树)
数据结构·leetcode