题目

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""。

示例 1:

输入: ["flower","flow","flight"]
输出: "fl"

示例 2:

输入: ["dog","racecar","car"]
输出: ""
解释: 输入不存在公共前缀。

说明:

所有输入只包含小写字母 a-z 。

算法

1.选取第一个字符串作为标准

2.第一个字符串的首位 和 第二个字符串的的首位 进行对比,如果首位相同,进入3

3.第一个字符串的首位 和 第三个字符串的的首位 进行对比,如果首位相同,....类似情况,

4.第2,3步把第一个字符串的首位和所有字符串的首位进行对比,对比结束后,进入5

5.第一个字符串的第2位 和 第二个字符串的的第2位 进行对比,如果第2位相同,....类似上面的情况

代码规划

一、定义

len:用strs.size()判断出来总共有几个字符串

i :代表第一个字符串的当前字符的位置,比如flower  i=1,代表是l

j: 代表目前对比的是第几个字符串

res:代表返回的结果,初始设为""

二、核心

while(第1个字符串当前字符位置是否小于字符串的长度)

  for(第几个字符)

    算法代码(10-16行)

三、解释19行代码

//append是string的新增
//substr(i,1)是取strs【0】的第i位开始后的一位
//也就相当于每次循环结束后取一位字符

正确代码

 class Solution {
public:
string longestCommonPrefix(vector<string>& strs) {
int length = strs.size();
int i = ;
bool flag = true; //标记是否满足匹配条件
string res = "";
if(length == )
return "";
while(i < strs[].length()){ //以第一个字符串作为标准
for(int j = ; j < length; j++){
if(strs[j] == "" || strs[j][i] != strs[][i]){
flag = false;
break;
}
}
if(flag == false)
return res;
res.append(strs[].substr(i,));
i++;
}
return res;
}
};

超时代码

算法(10-12行)

1.用第一个字符串作为标准

2.如果第二个字符串中没有不包含第一个字符串的话

3.那就把第一个字符串的最后一位删掉

4.直到删到和第二个字符串相等为止

5.然后到第10行,i+1,开始看现在删改后的第一个字符串是否被包含在第三个字符串中

6.如果不包含的话,那就再删掉现在第一个字符串的最后一位

结果

但是这个在leetcode上的话,是超时的,所以不能通过

思考

如果我先筛选出来最短的字符串,然后再用这个算法怎么样?留给明天去写

 class Solution {
public:
string longestCommonPrefix(vector<string>& strs) {
string s;
s = strs[];
if(strs.size() == )
return "";
if(strs.size() == )
return strs[];
for(int i=;i<strs.size();i++){
while(strs[i].find(s) != )
s=s.substr(,strs.size()-); }
return s;
}
};

原题链接

14. 最长公共前缀

参考链接

【leetcode】14-最长公共前缀【C++】

14. 最长公共前缀(C++)[简单]

Leetcode14._最长公共前缀的更多相关文章

  1. Python数据结构与算法_最长公共前缀(05)

    编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower","flow" ...

  2. [Swift]LeetCode14. 最长公共前缀 | Longest Common Prefix

    Write a function to find the longest common prefix string amongst an array of strings. If there is n ...

  3. leetcode-14最长公共前缀

    leetcode-14最长公共前缀 题目 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower& ...

  4. Leetcode13. 罗马数字转整数Leetcode14. 最长公共前缀Leetcode15. 三数之和Leetcode16. 最接近的三数之和Leetcode17. 电话号码的字母组合

    > 简洁易懂讲清原理,讲不清你来打我~ 输入字符串,输出对应整数 ![在这里插入图片描述](https://img-blog.csdnimg.cn/63802fda72be45eba98d9e4 ...

  5. LeetCode14.最长公共前缀

    编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower","flow" ...

  6. LeetCode14.最长公共前缀 JavaScript

    编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower","flow" ...

  7. 最长公共前缀的golang实现

    编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 输入: ["flower","flow",&quo ...

  8. LeetCode 14. 最长公共前缀(Longest Common Prefix)

    14. 最长公共前缀 14. Longest Common Prefix 题目描述 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". Lee ...

  9. [转][LeetCode]Longest Common Prefix ——求字符串的最长公共前缀

    题记: 这道题不难但是很有意思,有两种解题思路,可以说一种是横向扫描,一种是纵向扫描. 横向扫描:遍历所有字符串,每次跟当前得出的最长公共前缀串进行对比,不断修正,最后得出最长公共前缀串. 纵向扫描: ...

随机推荐

  1. NSDictionary和NSMaptable, NSArray,NSSet,NSOrderedSet和NSHashTable的区别

    NSSet, NSDictionary, NSArray是Foundation框架关于集合操作的常用类, 和其他标准的集合操作库不同, 他们的实现方法对开发者进行隐藏, 只允许开发者写一些简单的代码, ...

  2. JNI传递修改自定义Java Class数组数据

    声明:迁移自本人CSDN博客https://blog.csdn.net/u013365635 结合前面讲的2篇关于JNI的文章,这里直接把代码贴上,主要是要知道如果传递自定义Class Array的时 ...

  3. 实验吧web-易-what a fuck!这是什么鬼东西?

    打开链接是一大串符号,是js编码的一种,全部复制下来,粘贴在控制台中回车就拿到flag了.

  4. Python pip安装时You are using pip version 9.0.1, however version 18.0 is available. You should consider upgrading via the 'python -m pip install --upgrade pip' command.

    在我们安装第三方库的时候会在结尾出现如下两行内容 You are using pip version 9.0.1, however version 18.0 is available. You sho ...

  5. PAT Advanced 1090 Highest Price in Supply Chain (25) [树的遍历]

    题目 A supply chain is a network of retailers(零售商), distributors(经销商), and suppliers(供应商)–everyone inv ...

  6. Access修改窗体的名称,用于VBA代码的调用

  7. 使用linux服务器安装wordpress博客详细教程

    前言 最近读了<软技能:代码之外的生存指南>,这本书给了我很大的启示.之前虽然知道作为一个程序员,应该拥有自己的博客,以便于提升自己的知名度,但是并没有了解的过于详细.这本书描写博客的作用 ...

  8. Linux-线程同步之互斥锁

    1.互斥锁又叫互斥量(mutex) 2.相关函数:pthread_mutex_init  pthread_mutex_destroy   pthread_mutex_lock pthread_mute ...

  9. 用户交互Scanner

    用户交互Scanner java.util.Scanner Scanner类可以获取用户的输入. Java 5 通过Scanner类的next()和nextLine()方法获取输入的字符串 在读取前我 ...

  10. 初学C#之运算符和关系表达式

    ㈠运算符和关系表达式 一元运算符++.-- 前加和后加区别,事例++在后如下: ; ; //结果age=19 说明age++在表达式中age的值也+1.结果sum=8,原因age++,++在后用age ...