Leetcode14._最长公共前缀
题目
编写一个函数来查找字符串数组中的最长公共前缀。
如果不存在公共前缀,返回空字符串 ""。
示例 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. 最长公共前缀
参考链接
Leetcode14._最长公共前缀的更多相关文章
- Python数据结构与算法_最长公共前缀(05)
编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower","flow" ...
- [Swift]LeetCode14. 最长公共前缀 | Longest Common Prefix
Write a function to find the longest common prefix string amongst an array of strings. If there is n ...
- leetcode-14最长公共前缀
leetcode-14最长公共前缀 题目 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower& ...
- Leetcode13. 罗马数字转整数Leetcode14. 最长公共前缀Leetcode15. 三数之和Leetcode16. 最接近的三数之和Leetcode17. 电话号码的字母组合
> 简洁易懂讲清原理,讲不清你来打我~ 输入字符串,输出对应整数 
14. 最长公共前缀 14. Longest Common Prefix 题目描述 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". Lee ...
- [转][LeetCode]Longest Common Prefix ——求字符串的最长公共前缀
题记: 这道题不难但是很有意思,有两种解题思路,可以说一种是横向扫描,一种是纵向扫描. 横向扫描:遍历所有字符串,每次跟当前得出的最长公共前缀串进行对比,不断修正,最后得出最长公共前缀串. 纵向扫描: ...
随机推荐
- spyder.app制作图标
安装了 anaconda3, 自带spyder, 但是只能在terminal 中打开, 非常不友好. 模仿 anaconda3/目录下 Anaconda-Navigator.app, 制作了 spyd ...
- 吴裕雄--天生自然 JAVASCRIPT开发学习:弹窗
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script> ...
- 【mui webAPP】HBuilder创建的iOS平台设置沉浸式状态栏
应用占用全屏区域,而系统状态栏需要预留出系统状态栏高度. HBuilder创建的应用默认不使用沉浸式状态栏样式,需要进行如下配置开启:打开应用的manifest.json文件,切换到代码视图,在plu ...
- Django框架(七):模型(三) 关联、模型类的属性
1. 关联 1.1 模型类关系 关系型数据库的关系包括三种类型: ForeignKey:一对多,将字段定义在多的一端中. ManyToManyField:多对多,将字段定义在任意一端中. OneToO ...
- 计蒜客 引爆炸弹(DFS、并查集)
在一个 n×m 的方格地图上,某些方格上放置着炸弹.手动引爆一个炸弹以后,炸弹会把炸弹所在的行和列上的所有炸弹引爆,被引爆的炸弹又能引爆其他炸弹,这样连锁下去. 现在为了引爆地图上的所有炸弹,需要手动 ...
- Java8之深入理解Lambda
lambda表达式实战 从例子引出lambda 传递Runnable创建Thread java8之前 Thread thread=new Thread(new Runnable() { @Overri ...
- 京东云数据库 RDS助力企业便捷运维
iPhone6发布那年,京东在国贸等商圈送货最快速度数分钟,包括从下单到送达.这是一个极端的富含营销因素例子.即便如此,常态来看,隔天到货的这种业务模式,也是基于同样的支撑:营销业务.物流业务,大数据 ...
- 查看jks文件中的签名
1. 打开CMD命令行进入本机安装的jdk或jre下的bin目录. 2. 下来看图 keytool -list -v -keystore C:\Users\Administrator\Desktop\ ...
- ssh登录脚本
#!/usr/bin/expect set timeout 100 set passwd "your password" spawn shell expect "key& ...
- 题解 P1884 【[USACO12FEB]过度种植(银)Overplanting 】
什么,扫描线需要线段树? 那我第一个不干啊(其实是不会写) 这里介绍一种裸的扫描线: 我们根据x排序,对于相等的 \(x\) ,将 \(y\) 进入和退出分类讨论,然后全部放进set里面.每次 \(x ...