Leetcode题解(五)
17、Letter Combinations of a Phone Number
题目

针对输入的数字串,每一个数字都对应对个字符可以选择。因此可以直接采用递归的思想,依次遍历数字串的每一个数字,处理到当前数字时,余下的数字可以看出一个规模更小的子串来处理,这正符合递归的思想,将问题逐步化小。代码如下:
class Solution {
public:
vector<string> phoneNumber;
Solution()
{
phoneNumber.push_back("");
phoneNumber.push_back("");
phoneNumber.push_back("abc");//
phoneNumber.push_back("def");
phoneNumber.push_back("ghi");
phoneNumber.push_back("jkl");
phoneNumber.push_back("mno");
phoneNumber.push_back("pqrs");
phoneNumber.push_back("tuv");
phoneNumber.push_back("wxyz");
}
vector<string> letterCombinations(string digits) {
int index = ;
vector<string> res;
if("" == digits)
{
return res;
}
string str="";
letterCombinations(digits,,res,str);
return res;
}
void letterCombinations(const string digits,int index,vector<string>&res,string str)
{
if(digits[index] == '\0')
{
res.push_back(str);
return;
}
int count = phoneNumber[digits[index]-''].size();
for(int i=;i<count;i++)
{
letterCombinations(digits,index+,res,str+phoneNumber[digits[index]-''][i]);
}
}
};
-----------------------------------------------------------------------------------------------分割线------------------------------------------------------------------------------
18、4Sum(*)
题目

代码摘抄自网上:
class Solution {
public:
vector<vector<int> > fourSum(vector<int> &num, int target) {
// Start typing your C/C++ solution below
// DO NOT write int main() function
int nSize = num.size();
vector< vector<int> > result;
if (nSize < ) return result;
sort(num.begin(), num.end());
vector<int> mid();
set<string> isExit;
for (int i = ; i < nSize - ; ++i)
{
mid[] = num[i];
for (int j = i + ; j < nSize - ; ++j)
{
mid[] = num[j];
int l = j + ;
int r = nSize - ;
int sum = target - num[i] - num[j];
while(l < r)
{
int tmp = num[l] + num[r];
if (sum == tmp)
{
string str;
str += num[i];
str += num[j];
str += num[l];
str += num[r];
set<string>::iterator itr = isExit.find(str);
if (itr == isExit.end())
{
isExit.insert(str);
mid[] = num[l];
mid[] = num[r];
result.push_back(mid);
}
++l;
--r;
}
else if(sum > tmp)
++l;
else
--r;
}
}
}
return result;
}
};
-------------------------------------------------------------------------------------------------分割线---------------------------------------------------------------------------
19、Remove Nth Node From End of List
题目

由于是单链表,如果要删除某个节点,那必须定位到该节点的前一个节点,因此,需要对该节点分类:
a.如果删除的节点是最后一个节点,该节点有前驱节点,能够定位;但是后继节点为空
b.如果删除的节点是中间某一个节点,该节点有前驱节点,能够定位。因此a情况可以和b情况直接合并为一种情况;
c.如果删除的节点是首节点,该节点没有前驱。需要特殊处理;
题目也特别要求只能遍历一遍该链表。并且n值是合法的,如果输入的n值可能是非法,那需要对n值做判断,使得函数的鲁棒性比较强。针对n值可能的输入:
a.n<=0,可以直接判断;
b.n>链表长度,需要进行判断,判断方式详见代码。
代码如下:
class Solution {
public:
ListNode* removeNthFromEnd(ListNode* head, int n) {
//双指针同步,先让某一个指针走n-1步
if (NULL == head || n<=)
{
return NULL;
}
ListNode *first,*second;
first = head;
int i=;
while(i<n)
{
first = first->next;
if(NULL == first && i+<n)//n值大于链表长度
return NULL;
i++;
}
if(NULL == first)//删除首节点
return head->next;
second = head;
first = first->next;
while(first != NULL)
{
first = first->next;
second = second->next;
}
second->next = second->next->next;
return head;
}
};
-----------------------------------------------------------------------------------------------分割线-----------------------------------------------------------------------------
20、Valid Parentheses
题目

栈的运用。直接上代码:
class Solution {
public:
bool isValid(string s) {
stack<char> myStack;
int i=;
while(s[i]!='\0')
{
if(s[i]=='('||s[i]=='['||s[i]=='{')
{
myStack.push(s[i]);
}
else if(s[i]==')')
{
if(myStack.empty())
return false;
if(myStack.top() == '(')
myStack.pop();
else
return false;
}
else if(s[i]==']')
{
if(myStack.empty())
return false;
if(myStack.top() == '[')
myStack.pop();
else
return false;
}
else if(s[i]=='}')
{
if(myStack.empty())
return false;
if(myStack.top() == '{')
myStack.pop();
else
return false;
}
i++;
}
if(myStack.empty())
return true;
else
return false;
}
};
Leetcode题解(五)的更多相关文章
- 【LeetCode题解】二叉树的遍历
我准备开始一个新系列[LeetCode题解],用来记录刷LeetCode题,顺便复习一下数据结构与算法. 1. 二叉树 二叉树(binary tree)是一种极为普遍的数据结构,树的每一个节点最多只有 ...
- LeetCode第五天
leetcode 第五天 2018年1月6日 22.(566) Reshape the Matrix JAVA class Solution { public int[][] matrixReshap ...
- leetcode题解-122买卖股票的最佳时期
题目 leetcode题解-122.买卖股票的最佳时机:https://www.yanbinghu.com/2019/03/14/30893.html 题目详情 给定一个数组,它的第 i 个元素是一支 ...
- 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)
目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...
- 【LeetCode题解】225_用队列实现栈(Implement-Stack-using-Queues)
目录 描述 解法一:双队列,入快出慢 思路 入栈(push) 出栈(pop) 查看栈顶元素(peek) 是否为空(empty) Java 实现 Python 实现 解法二:双队列,入慢出快 思路 入栈 ...
- 【LeetCode题解】232_用栈实现队列(Implement-Queue-using-Stacks)
目录 描述 解法一:在一个栈中维持所有元素的出队顺序 思路 入队(push) 出队(pop) 查看队首(peek) 是否为空(empty) Java 实现 Python 实现 解法二:一个栈入,一个栈 ...
- 【LeetCode题解】844_比较含退格的字符串(Backspace-String-Compare)
目录 描述 解法一:字符串比较 思路 Java 实现 Python 实现 复杂度分析 解法二:双指针(推荐) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记可以 ...
- 【LeetCode题解】25_k个一组翻转链表(Reverse-Nodes-in-k-Group)
目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记 ...
- 【LeetCode题解】24_两两交换链表中的节点(Swap-Nodes-in-Pairs)
目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度要求) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解 ...
- 【LeetCode题解】347_前K个高频元素(Top-K-Frequent-Elements)
目录 描述 解法一:排序算法(不满足时间复杂度要求) Java 实现 Python 实现 复杂度分析 解法二:最小堆 思路 Java 实现 Python 实现 复杂度分析 解法三:桶排序(bucket ...
随机推荐
- jmeter测试教程
http://www.cnblogs.com/TankXiao/p/4045439.html
- WinForm事件中的Object sender和EventArgs e参数
Windows程序有一个事件机制.用于处理用户事件. 在WinForm中我们经常需要给控件添加事件.例如给一个Button按钮添加一个Click点击事件.给TextBox文本框添加一个KeyPress ...
- Block使用的简单总结
一.Block简单的使用 1.block当作参数来传递 如下定义一个没有返回值无参数的block,并把它作为参数,让系统调用,注意:这里是系统在调用,不是我们调用 那么为什么需要把block当作参数去 ...
- C#中 什么是装箱和拆箱
装箱:将值类型包装为引用类型 拆箱:将引用类型转换为值类型 例如 objetct obj = null; obj = ; //装箱 int i = (int) obj; //拆箱
- ListBox数据绑定无效
public class DataList { public List<string> listSource; private DataTable table; public DataLi ...
- Jmeter脚本录制方法(二)——手工编写脚本(jmeter与fiddler结合使用)
jmeter脚本录制方法可以分三种,前几天写的一篇文章中,已介绍了前两种,今天来说下第三种,手工编写脚本,建议使用这一种方法,虽然写的过程有点繁琐,但调试脚本比前两者方式都要便捷. 首先来看下三种方式 ...
- JSONP、图片Ping、XMLHttpRequest2.0等跨域资源请求(CORS)
跨域:当协议.主域名.子域名.端口号中任意一个不相同时都不算同一个域,而在不同域之间请求数据即为跨域请求.解决方法有以下几种(如有错误欢迎指出)以请求图片url为例: 1.通过XMLHttpReque ...
- iKcamp出品|微信小程序|工具安装+目录说明|基于最新版1.0开发者工具初中级教程分享
iKcamp官网:http://www.ikcamp.com 访问官网更快阅读全部免费分享课程:<iKcamp出品|全网最新|微信小程序|基于最新版1.0开发者工具之初中级培训教程分享>. ...
- es6的箭头函数
1.使用语法 : 参数 => 函数语句; 分为以下几种形式 : (1) ()=>语句 ( )=> statement 这是一种简写方法省略了花括号和return 相当于 ()=&g ...
- 【特效】select美化
select的默认样式往往很丑,为保证页面样式风格统一,需要对select进行美化.虽然其美化的插件很多,一搜一大把,但是需要引入长长的css文件和js文件实在是件头痛的事.其实select的实现原理 ...