LeetCode Weekly Contest 12
1. 第一题
看完题目后,肯定先对houses和heaters排序,然后考虑贪心可以么,我那时候没有想出来,然后看到可以O(n)的判断一个半径是否满足要求,就对半径[0,1e9]进行二分,然后就a了。
其实,排完序可以进行贪心,对每一个houses,找到最近的heaters,左右2边的,求最小,这个可以通过二分来做,然后不断更新结果,求出最小值的最大值,这应该算是正常的解法。
我认为应该算是medium,easy难度设的有点低。
2. 第二题
字符串题目,其实看到这题,我是不大乐意的,因为这题需要考虑各种边界条件,而我写出的代码也是比较丑的。
这题没有什么套路,直接考虑说明中各种边界条件就可以了。
3.第三题
找了例子写了一下,发现贪心不行,因为不知道0和1,应该尽可能的使用哪一个,然后统计个数,忽略每个字符串01的顺序,然后考虑dp。就是每个每个字符串选还是不选,结果的最大值,简单的背包问题。
注意从大到小更新,搞清楚转移方程。
4.第四题
一看题目,完全懵逼,根本无从下手。我一般先做可以出结果的题目,这次的先做2,3题,看到第四题,感觉不行,就写1题,写完再看了看第四题,就直接放弃了。
题解看的这里:
http://bookshadow.com/weblog/2016/12/11/leetcode-encode-string-with-shortest-length/
分析的很棒,我不知道怎么分析复杂度。看题目的时候,长度只有160,发现n^2的复杂度也不会超时,但是没思路。
想起来,跟 411 Minimum Unique Word Abbreviation 差不多。
根据上面的题解,写的代码。
class Solution {
public:
map<string, string> ma;
//string encode(string s);
string work(string s) {
string res = s;
int n = s.size();
for (int i = ; i <= n / ; i++) {
bool f = ;
if(n % i != ) continue;
for (int j = ; j < s.size(); j++) {
if(s[j] != s[j % i]) {
f = ;
break;
}
}
if(f) {
stringstream s1;
s1 << n / i << '[' << encode(s.substr(, i)) << ']';
string t = s1.str();
if(t.size() < res.size()) res = t;
}
}
return res;
}
string encode(string s) {
int n = s.size();
if(n <= ) return s;
if(ma.count(s)) return ma[s];
string res = s;
for (int i = ; i <= s.size(); i++) {
string left = s.substr(, i), right = s.substr(i);
string t = work(left) + encode(right);
if(res.size() > t.size()) res = t;
}
return ma[s] = res;
}
};
其实可以写一下当初为什么没有想法,或者是有一点想法,不知道怎么下手,或者有什么疑问。
问题一:怎么处理循环几次的问题,不知道怎么考虑,要用什么后缀树,前缀树处理么?其实,这个过程是要通过枚举来处理,枚举切分长度,然后判读是否是这个长度的的重复串。真的,这个问题之前真的不知道怎么处理!
问题二:中括号里面的编码怎么处理,其实这里猜也可以猜到:递归调用encode
问题三:怎么处理需要编码和不需要编码的部分,就是上面代码的33行的处理部分,这个怎么分析出来的。
问题四:上面这样搞的复杂度是多少,1s的时限内是否可以运行完毕,这些都是需要考虑的!
反正,就上面这么多疑问,下次遇到类似的问题的时候,应该知道怎么下手吧!
LeetCode Weekly Contest 12的更多相关文章
- 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 26 Q2】Longest Uncommon Subsequence II
[题目链接]:https://leetcode.com/contest/leetcode-weekly-contest-26/problems/longest-uncommon-subsequence ...
- 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 Q1】Longest Uncommon Subsequence I
[题目链接]:https://leetcode.com/contest/leetcode-weekly-contest-26/problems/longest-uncommon-subsequence ...
随机推荐
- (转)从Membership 到 .NET4.5 之 ASP.NET Identity
引入 - 用户信息是如何存在数据库中的 我们前两篇都只讲到了怎么用Membership注册,登录等,但是我们漏掉了一个很重要并且是基本上每个用Membership的人都想问的,我的用户信息怎么保存?我 ...
- c# 计算两日期的工作时间间隔(排除非工作日)及计算下一个工作时间点.
一个日期段如工作时间为 8:00 至 17:00 public class TimeHelper { /// <summary> /// 计算时间间隔 /// </summary&g ...
- 关于禁止Android scrollView 因内容变化而自动滚动 android:descendantFocusability
出现这种情况是因为你让scrollview获得了焦点,所以它才会滚动.如果你百度了以后,你可能会发现有些博客会说让焦点停在固定的一个view中就可以了.这对于不存在刷新的页面确实是可以的,但是当你出现 ...
- redis 简介
Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富.有字符串,链表,集 合和有序集合.支持在服务器端计算集合的并,交和补集(diff ...
- 3.4html学习笔记之表格
<table border=""style="border-collapse:collapse"> <caption>表格</ca ...
- Data Structure 之 算法设计策略
1. 穷举法 基本思想:列举问题的所有可能解,并用约束条件逐一进行判定,找出符合约束条件的解. 穷举法的关键在于问题的可能解的列举和可能解的判别. 例如:凑数问题 2. 递归技术 定义:直接或间接调用 ...
- Json.Net学习(1) 实现简单的序列化和反序列化
Attributes 可以用来控制Json.Net如何序列化和反序列化.Net对象. >JsonObjectAttribute--标记在类上,用于控制该类如何被序列化为一个Json对象(JSON ...
- 1.4.2 solr字段类型--(1.4.2.2)solr附带的字段类型
1.4.2 solr字段类型 (1.4.2.1) 字段类型定义和字段类型属性. (1.4.2.2) solr附带的字段类型 (1.4.2.3) 使用货币和汇率 (1.4.2.4) 使用Dates(日期 ...
- Gradle实战:不同编译类型的包同设备共存
查看原文:http://blog.csdn.net/u010818425/article/details/52335844 Gradle实战系列文章: <Gradle基本知识点与常用配置> ...
- C#中常用的排序算法的时间复杂度和空间复杂度
常用的排序算法的时间复杂度和空间复杂度 常用的排序算法的时间复杂度和空间复杂度 排序法 最差时间分析 平均时间复杂度 稳定度 空间复杂度 冒泡排序 O(n2) O(n2) 稳定 O(1) 快速排序 ...