> 简洁易懂讲清原理,讲不清你来打我~

输入字符串,输出对应整数

![在这里插入图片描述](https://img-blog.csdnimg.cn/63802fda72be45eba98d9e4c99f0160b.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/0ce225c2d0e545e2abe9518d238a9429.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/2cc144b3db264abba6e4057953b6d153.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/059524e826544166b0cf5f91d6bcc6f7.png)
简单的思路
罗马数字映射整数,遍历罗马字符串,当第i个对应的字符串小于第i+1个,减法,否则加法

精确的定义
RomanToNum是罗马字符映射数字的哈希表
i是字符串遍历到的当前下标
ans是罗马字符串对应的最终整数

```cpp
class Solution {
public:
int romanToInt(string s) {
unordered_map<char,int>RomanToNum={
{'I',1},
{'V',5},
{'X',10},
{'L',50},
{'C',100},
{'D',500},
{'M',1000}
};
int ans=0;
for(int i=0;i<s.size();i++){
if(i+1<s.size()&&RomanToNum[s[i+1]]>RomanToNum[s[i]]){
ans-=RomanToNum[s[i]];
}else{
ans+=RomanToNum[s[i]];
}
}
return ans;
}
};
```

> 简洁易懂讲清原理,讲不清你来打我~

Leetcode14. 最长公共前缀

输入字符串数组,输出字符串为公共前缀

![在这里插入图片描述](https://img-blog.csdnimg.cn/bb4bce9ed73940f79919032f0a043c13.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/53c5e14222af4fce9bb75e9f0334a4c3.png)

> 暴力

简单的思路
第一个作为模板,对每个字符数组进行匹配,对于每个字符串,从头到尾匹配,不能匹配或者超出最右时就不再匹配并更新最右边界

精确的定义
mostRight是最长公共前缀到最右的地方
right是两字符串公共前缀最右的地方
i是正在匹配的字符串下标
str1是拿来匹配的模板

```cpp
class Solution {
public:
string longestCommonPrefix(vector<string>& strs) {
if(strs.size()==0)return "";
string str1=strs[0];
int mostRight=str1.size();
for(int i=1;i<strs.size();i++){
int right=-1;
while(right+1<strs[i].size()&&right+1<=mostRight&&strs[i][right+1]==str1[right+1]){
right++;
}
mostRight=right;
}
if(mostRight==-1)return "";
return str1.substr(0,mostRight-0+1);
}
};
```

时间复杂度Omn,m是字符串平均长度,n是字符串数量,最差情况每个字符串每个字符都遍历

1

Leetcode15. 三数之和

数组找到3个元素,和为0,输出
![在这里插入图片描述](https://img-blog.csdnimg.cn/e5a7f0c4795e4a1e88e96dfcc7eada3f.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/4929d1540ae44f8d9cfe0cd0eeb0029c.png)
详细思路
sort,先找一个i,剩余两个从i右边开始,用双指针靠近找出所有满足的三元组,当i和i-1,left和left-1,right和right+1相同时continue;

精确的定义
i第一个元素下标
left第二个元素下标
right第三个元素下标
ans所有满足的数组

```cpp
class Solution {
public:
vector<vector<int>> threeSum(vector<int>& nums) {
vector<vector<int>>ans;
if(nums.size()<3)return ans;
sort(nums.begin(),nums.end());
for(int i=0;i<nums.size()-2;i++){
if(i-1>=0&&nums[i]==nums[i-1])continue;
int left=i+1,right=nums.size()-1;
while(left<right){
if(left-1>=i+1&&nums[left]==nums[left-1]){
left++;
continue;
}
else if(right+1<=nums.size()-1&&nums[right]==nums[right+1]){
right--;
continue;
}
if(nums[left]+nums[right]+nums[i]==0){
ans.push_back({nums[i],nums[left],nums[right]});
left++;
right--;
}
else if(nums[left]+nums[right]+nums[i]<0)left++;
else if(nums[left]+nums[right]+nums[i]>0)right--;
}
}
return ans;
}
};
```

踩过的坑
去重
```cpp
if(i-1>=0&&nums[i]==nums[i-1])continue;

if(left-1>=i+1&&nums[left]==nums[left-1]){
left++;
continue;
}
else if(right+1<=nums.size()-1&&nums[right]==nums[right+1]){
right--;
continue;
}
```
Leetcode16. 最接近的三数之和
![在这里插入图片描述](https://img-blog.csdnimg.cn/af4cf4dcea884377bf268f9252fe3a2a.png)
详细的思路
sort,对于每一个第一个元素,leftright两侧向中间逼近,保存最接近的和,绝对值更小的和要保存,大于的话right--小于的话left++

精确的定义
i第一个元素
left第二个元素
right第三个元素
ans最接近的和

```cpp
class Solution {
public:
int threeSumClosest(vector<int>& nums, int target) {
sort(nums.begin(),nums.end());
int ans=0x3f3f3f3f;
for(int i=0;i<nums.size()-2;i++){
int left=i+1,right=nums.size()-1;
while(left<right){
ans=abs(nums[i]+nums[left]+nums[right]-target)<abs(ans-target)?nums[i]+nums[left]+nums[right]:ans;
if(nums[i]+nums[left]+nums[right]==target)return target;
else if(nums[i]+nums[left]+nums[right]<target)left++;
else if(nums[i]+nums[left]+nums[right]>target)right--;
}
}
return ans;
}
};
```
踩过的坑

```cpp
int ans=0x3f3f3f3f;
```

Leetcode17. 电话号码的字母组合
![在这里插入图片描述](https://img-blog.csdnimg.cn/157d8ecc20f44fdd92cd9f38f6656815.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/22f7cece8bbd47da8b4c97ab2c718529.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/31c3ac0936eb4771807727c77d931322.png)

详细的思路
哈希表映射数字对应的字符串,从第0层开始,找到该层数字对应的字符串,遍历字符串,将第一个字符放到数组并进入下一层,或者不要这个字符而尝试第二个字符,当层数=最后一个数字也用完了就结束

精确的定义
numToStr哈希表数字映射字符串
depth递归层数,也是处理第几个数字
str该层对应的字符串
c字符串中的字符
ans1某一种组合
ans所有组合

```cpp
class Solution {
public:
unordered_map<char,string>numToStr={
{'2',"abc"},
{'3',"def"},
{'4',"ghi"},
{'5',"jkl"},
{'6',"mno"},
{'7',"pqrs"},
{'8',"tuv"},
{'9',"wxyz"}
};
vector<string> letterCombinations(string digits) {
if(digits.size()==0)return {};
vector<string>ans;
string ans1;
dfs(digits,ans,ans1,0);
return ans;
}
void dfs(const string&digits,vector<string>&ans,string&ans1,int depth){
if(depth==digits.size()){
ans.push_back(ans1);
return ;
}
string str=numToStr[digits[depth]];
for(auto c:str){
ans1.push_back(c);
dfs(digits,ans,ans1,depth+1);
ans1.pop_back();
}
}
};
```

> 喜欢简洁易懂还能讲清楚原理博客的小伙伴就关注关注这个非常高产的博主呀,下次再会~

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

  1. leetcode-14最长公共前缀

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

  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. LeetCode14.最长公共前缀

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

  4. LeetCode14.最长公共前缀 JavaScript

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

  5. leetcode14最长公共前缀

    class Solution { public: string longestCommonPrefix(vector<string>& strs) { ) return " ...

  6. leetcode14:最长公共字符串

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

  7. Leetcode14._最长公共前缀

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

  8. [LeetCode]14.最长公共前缀(Java)

    原题地址: longest-common-prefix 题目描述: 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入:st ...

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

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

随机推荐

  1. STM32使用DMA发送串口数据

    1.概述 上一篇文章<STM32使用DMA接收串口数据>讲解了如何使用DMA接收数据,使用DMA外设和串口外设,使用的中断是串口空闲中断.本篇文章主要讲解使用DMA发送数据,不会讲解基础的 ...

  2. adb基础命令

    adb运行原理: 启动一个 adb 客户端时,此客户端首先检查是否有已运行的 adb 服务器进程.如果没有,它将启动服务器进程.当服务器启动时,它与本地 TCP 端口 5037 绑定,并侦听从 adb ...

  3. 狂神说linux笔记:基本操作

    Linux介绍 Linux的概述本文就不赘述了,如果想仔细了解的小伙伴可以百度Linux的历史或者看看狂神的原文.本文主要写linux的操作过程知识点. 狂神的原文如下: https://mp.wei ...

  4. Python小白的数学建模课-07 选址问题

    选址问题是要选择设施位置使目标达到最优,是数模竞赛中的常见题型. 小白不一定要掌握所有的选址问题,但要能判断是哪一类问题,用哪个模型. 进一步学习 PuLP工具包中处理复杂问题的字典格式快捷建模方法. ...

  5. 【NX二次开发】体素特征相关函数(块、柱、锥、球)

    NX Open允许用户创建和查询所有基本体素特征,通过API函数建立基本体素特征返回的是相应的特征标识,如果需要可以通过函数UG_MODL_ask_feat_body()获得特征对应的实体对象标识.基 ...

  6. kerberos安装配置

    目录 前言 服务端安装 组件安装 配置krb5.conf 配置kdc.conf 配置kadm5.acl 创建kdc数据库 在server端创建一个管理员账号,方便远程登录管理kerberos 正式启动 ...

  7. 面试热点|理解TCP/IP传输层拥塞控制算法

    0x00.前言 通过本文你将了解到以下内容: 拥塞控制概念以及其背景 流量控制和拥塞控制的区别与联系 拥塞控制主要过程详解 伙伴们认真学习一下,让offer来得更猛烈些吧! 0x01.TCP/IP协议 ...

  8. c#根据名称反射对应的枚举类型

    今天遇到了要配置串口的停止位,这个时候直接反射枚举比较方便. 第一反射所有的枚举值 FieldInfo[] fieldInfoes= typeof(StopBits).GetFields(Bindin ...

  9. Java并发之ReentrantLock源码解析(一)

    ReentrantLock ReentrantLock是一种可重入的互斥锁,它的行为和作用与关键字synchronized有些类似,在并发场景下可以让多个线程按照一定的顺序访问同一资源.相比synch ...

  10. 01 JumpServer安装

    1.0.环境说明: 操作系统类型 主机名称 用户及密码 角色 eth0(Vmnet8) eth1(Vmnet1) 防火墙状态 selinux centos7.4 controlnode root:12 ...