LeetCode Weekly Contest 27
1. 557. Reverse Words in a String III
分割字符串,翻转。
 class Solution {
 public:
 string reverseWords(string s) {
     int n = s.size();
     if(n < ) return s;
     string res;
     int i = ;
     n += ;
     s += " ";
     int last = ;
     while(i < n) {
         last = i;
         while(i < n && s[i] != ' ') i++;
         string t = s.substr(last, i - last);
         reverse(t.begin(), t.end());
         res += t + " ";
         i++;
     }
     return res.substr(, n - );
 }
 };
2. 554. Brick Wall
这刚好是以前做的hihocode的一道题目:https://hihocoder.com/problemset/problem/1494
就是统计边界的最大次数,然后n- max求出最小的穿过次数。
 class Solution {
 public:
 int leastBricks(vector<vector<int>>& wall) {
     int n = wall.size();
     if(n == ) return ;
     map<int, int> ma;
     int res = ;
     for (vector<int> &it:wall) {
         int m = it.size();
         int s = ;
         for (int i = ; i < m - ; i++) {
             s += it[i];
             ma[s]++;
             res = max(res, ma[s]);
         }
     }
     return n - res;
 }
 };
3. 556. Next Greater Element III
要求下一个比较大的,可以采用next_permutation来做,然后判断下是不是真的比n大,然后还要check是否超过int的表示范围。
 class Solution {
 public:
 int nextGreaterElement(int n) {
     if(n < ) return -;
     vector<int> v;
     int t = n;
     while(t > ) {
         v.push_back(t % );
         t /= ;
     }
     int sz = v.size();
     //cout << sz << endl;
     if(sz == ) return -;
     reverse(v.begin(), v.end());
     if(next_permutation(v.begin(), v.end())) {
         long long res = ;
         for (int t : v) {
             res = res *  + t;
         }
         if(res > INT_MAX)
             return -;
         return res;
     } else
     return -;
 }
 };
4. 549. Binary Tree Longest Consecutive Sequence II
这个题跟求二叉树的最长路径的方法是一致的,维护信息,以及更新结果。
我当时写的有点复杂,只需要维护每个点的最长上升和下降长度就行。注意:题目要求必须连续。
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
int res;
typedef pair<pair<int, int>, pair<int, int>> pp;
typedef pair<int, int> pii;
pair<pair<int, int>, pair<int, int>> work(TreeNode* root) {
if(!root) {
return {{,}, {, } };
}
if(!root->left && !root->right) {
int v = root->val;
res = max(res, );
return {{, v}, {, v} };
}
int v = root->val;
pp m1 = work(root->left), m2 = work(root->right);
int a1 = m1.first.first, a2 = m1.first.second, b1 = m1.second.first, b2 = m1.second.second;
int ta1 = m2.first.first, ta2 = m2.first.second, tb1 = m2.second.first, tb2 = m2.second.second;
int ra1 = , ra2 = v, rb1 = , rb2 = v;
if(v == a2 + ) {
ra1 = a1 + ;
}
if(v == ta2 + ) {
ra1 = max(ra1, ta1 + );
}
if(v == b2 - ) {
rb1 = b1 + ;
}
if(v == tb2 - ) {
rb1 = max(rb1, tb1 + );
}
if(v == a2 + && v == tb2 - ) {
res = max(res, + a1 + tb1);
}
if(v == ta2 + && v == b2 - ) {
res = max(res, + ta1 + b1);
}
res = max(res, max(ra1, rb1));
return {{ra1, ra2}, {rb1, rb2} }; }
int longestConsecutive(TreeNode* root) {
if(!root) return ;
res = ;
work(root);
return res;
}
};
LeetCode Weekly Contest 27的更多相关文章
- LeetCode Weekly Contest 8
		LeetCode Weekly Contest 8 415. Add Strings User Accepted: 765 User Tried: 822 Total Accepted: 789 To ... 
- leetcode weekly contest 43
		leetcode weekly contest 43 leetcode649. Dota2 Senate leetcode649.Dota2 Senate 思路: 模拟规则round by round ... 
- LeetCode Weekly Contest 23
		LeetCode Weekly Contest 23 1. Reverse String II Given a string and an integer k, you need to reverse ... 
- Leetcode Weekly Contest 86
		Weekly Contest 86 A:840. 矩阵中的幻方 3 x 3 的幻方是一个填充有从 1 到 9 的不同数字的 3 x 3 矩阵,其中每行,每列以及两条对角线上的各数之和都相等. 给定一个 ... 
- LeetCode Weekly Contest
		链接:https://leetcode.com/contest/leetcode-weekly-contest-33/ A.Longest Harmonious Subsequence 思路:hash ... 
- 【LeetCode Weekly Contest 26 Q4】Split Array with Equal Sum
		[题目链接]:https://leetcode.com/contest/leetcode-weekly-contest-26/problems/split-array-with-equal-sum/ ... 
- 【LeetCode Weekly Contest 26 Q3】Friend Circles
		[题目链接]:https://leetcode.com/contest/leetcode-weekly-contest-26/problems/friend-circles/ [题意] 告诉你任意两个 ... 
- 【LeetCode Weekly Contest 26 Q2】Longest Uncommon Subsequence II
		[题目链接]:https://leetcode.com/contest/leetcode-weekly-contest-26/problems/longest-uncommon-subsequence ... 
- 【LeetCode Weekly Contest 26 Q1】Longest Uncommon Subsequence I
		[题目链接]:https://leetcode.com/contest/leetcode-weekly-contest-26/problems/longest-uncommon-subsequence ... 
随机推荐
- tomcat ider配置
			xml文件配置: <servlet> <servlet-name>test1</servlet-name>//设定java文件链接的锚点 <servlet-c ... 
- vmware Horizon 7 与远程桌面(mstsc)兼容性问题解决办法
			关于Horizon 7 Agent与远程桌面(mstsc)兼容性问题解决办法 在Horizon 7环境中,在桌面模板安装了Horizon Agent后,就无法直接通过微软的远程桌面(mstsc)工具连 ... 
- mint-ui  取值
			//slots:[{values: ['年假', '事假', '病假', '婚假', '其他']}], slots:[{values: []}], onValuesChange(picker,valu ... 
- 【剑指Offer】5、用两个栈实现队列
			题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 解题思路: 本题的基本意图是:用两个后入先出的栈来实现先入先出的队列.对于这个问题,我 ... 
- 纯CSS 3D翻转一个面(翻转导航菜单 立方体)
			在做练习的时候学到css的翻转导航菜单,原代码有点让人头疼,通过对其css的参数一点点研究了其实现过程. 这里推荐大家研究这个3D翻转动画的代码. 我的github:swarz,欢迎给老弟我++星星 ... 
- linux基础随记
			1.cd 切换路径 cd ~vbird 进入这个用户的主目录cd ~ 进入root这个目录下cd .. 进入root上层目录cd - 进入root这个目录下cd /var/spool/mail 直接访 ... 
- PHP和zookeeper结合实践
			Zookeeper 简单介绍 Apache Zookeeper是开发和维护开源服务器的服务,它能够实现高度可靠的分布式协调. 安装Zookeeper(无需安装) wget http://mirror. ... 
- Problem 52
			Problem 52 It can be seen that the number, 125874, and its double, 251748, contain exactly the same ... 
- 【Codeforces 639B】Bear and Forgotten Tree 3
			[链接] 我是链接,点我呀:) [题意] [题解] 首先,因为高度是h 所以肯定1下面有连续的h个点依次连成一条链.->用了h+1个点了 然后,考虑d这个约束. 会发现,形成d的这个路径,它一定 ... 
- VirtualBox虚拟机下 解决centos系统无法上网的问题
			首先,在VirtualBox中设置网卡连接方式:点“设置”,在弹出的界面中点“网络”,最后选择“连接方式”为“桥接网卡”或者网都可以络地址转换 这两种我试了试都可以 接下来修改一个文件就行: 1.打 ... 
