【Leetcode周赛】从contest-71开始。(一般是10个contest写一篇文章)
Contest 71 ()
Contest 72 ()
Contest 73 (2019年1月30日模拟)
链接:https://leetcode.com/contest/weekly-contest-73
结果:2/4,会做第一题和第三题,第二题和第四题不会做。
【788】Rotated Digits(第一题 4分)(谷歌tag)
给了一个 good number 的定义,X is a good number if after rotating each digit individually by 180 degrees, we get a valid number that is different from X.
0, 1, 8旋转之后是本身,2,5旋转之后互为另一个数,6,9 同 2,5。
给定一个 N,问 1~N 里面有多少个 good number?(N < 10000)
题解:直接枚举。注意旋转是说 每个数字单独旋转,并不是把整个数旋转。
class Solution {
public:
int rotatedDigits(int N) {
unordered_map<int, int> mp;
mp[] = , mp[] = , mp[] = , mp[]= , mp[] = , mp[] = , mp[] = ;
int ans = ;
for (int i = ; i <= N; ++i) {
string s = to_string(i);
string rev = "";
bool valid = true;
for (auto c : s) {
if (mp.find(c-'') == mp.end()) {
valid = false;
break;
}
rev += string(, mp[c-''] + '');
}
if (valid && s != rev && rev[] != '') {
ans++;
}
}
return ans;
}
};
【789】Escape The Ghosts(第二题 5分)逃离鬼魂(谷歌tag,数学题)
假设你站在原点,有个去的目标 target 坐标,在二维平面上有一些鬼魂(鬼也有坐标)。每一步,你和鬼魂都能上下左右移动一格。问有没有可能在鬼怪抓到你之前,到达target。如果你和鬼怪同时到达target的话,那么鬼赢了。
题解:我比赛的时候想成了比较复杂的bfs,去模拟每个位置。幸好没有写。本题的本质是只要你和target 的曼哈顿距离小于任何一个鬼怪距离target的目标距离,你就有可能会赢。所以只要判断一下距离就行了。
class Solution {
public:
bool escapeGhosts(vector<vector<int>>& ghosts, vector<int>& target) {
const int dist = abs(target[]) + abs(target[]);
for (auto& ele : ghosts) {
int d = abs(target[] - ele[]) + abs(target[] - ele[]);
if (d < dist) {
return false;
}
}
return true;
}
};
比赛的时候理解有问题,我一直以为某个时间人和鬼都必须要移动,不能站着不动。但是总监说不能站着不动的话,这题的难度也没有增加,因为如果有个鬼到target的距离和人到target距离如果差了一步的话,人就能到target,如果差了两步的话,鬼就能先离开,然后再回到target,所以这个时候鬼赢了。
然后还有一个变种,如果鬼不能到target,它最多在target周围四个格子,有点像猫和老鼠那题。
【791】Custom Sort String(第三题 5分)
给了两个字符串 S 和 T,S 定义了一种新的字母顺序,要求把 T 按照 S 定义的顺序排序。
题解:我是先用了一个 hashmap 记录了 T 的每个字母的频次,然后再遍历一遍 S, 构造ans字符串,最后遍历hashmap中剩下的字符,组成新的字符串。
class Solution {
public:
string customSortString(string S, string T) {
const int n = T.size();
unordered_map<char, int> mp;
for (int i = ; i < n; ++i) {
mp[T[i]]++;
}
string ret;
for (auto c : S) {
if (mp.find(c) == mp.end() || mp[c] == ) {continue;}
ret += string(mp[c], c);
mp[c] = ;
}
for (auto ele : mp) {
if (ele.second > ) {
ret += string(ele.second, ele.first);
}
}
return ret;
}
};
【790】Domino and Tromino Tiling(第四题 5分)
给了多米诺骨牌,有两种形状,
XX <- domino XX <- "L" tromino
X
给定一个 N 问有多少种填充方案能填满 2 * N 个格子。答案要对 1e9+7 取模。
题解:dp做。
Contest 74 (2019年1月31日模拟)
链接:https://leetcode.com/contest/weekly-contest-74
Contest 75 (2019年1月31日模拟)
链接:https://leetcode.com/contest/weekly-contest-75
Contest 77 (2019年2月3日模拟)
链接:https://leetcode.com/contest/weekly-contest-77
总结:做出来三道题。3/4
【806】Number of Lines To Write String(第一题 4分)
给了一个数组,数组中的元素作为 'a' ~ 'z' 的每个占位符的宽度。每行最多100个字符宽度,问给了一个字符串,返回两个数字,一个是这个字符串需要占多少行,第二个是这个字符串的最后一行有多少个字符。
Example :
Input:
widths = [10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10]
S = "abcdefghijklmnopqrstuvwxyz"
Output: [3, 60]
Explanation:
All letters have the same length of 10. To write all 26 letters,
we need two full lines and one line with 60 units.
题解:用个 curSum 的变量记录当前行有多少个字符,当 curSum 大于 100 的时候就换行。
class Solution {
public:
vector<int> numberOfLines(vector<int>& widths, string S) {
const int n = S.size();
int curLen = ;
vector<int> ans(, );
for (int i = ; i < n; ++i) {
curLen += widths[S[i]-'a'];
if (curLen > ) {
ans[]++;
curLen = widths[S[i]-'a'];
}
}
ans[] += ;
ans[] = curLen;
return ans;
}
};
【804】Unique Morse Code Words(第二题 4分)
给了一个数组作为 'a' 到 'z' 的摩斯码编码,给了一个 word list, 不同的单词可能有相同的莫斯码编码,返回有多少不同的摩斯码编码的种类。
题解:遍历,用set去除重复。
class Solution {
public:
int uniqueMorseRepresentations(vector<string>& words) {
vector<string> morse = {".-","-...","-.-.","-..",".","..-.","--.","....","..",".---","-.-",".-..","--","-.","---",".--.","--.-",".-.","...","-","..-","...-",".--","-..-","-.--","--.."};
set<string> st;
for (auto& w : words) {
string str;
for (auto& c : w) {
str += morse[c - 'a'];
}
st.insert(str);
}
return (int)st.size();
}
};
【807】Max Increase to Keep City Skyline(第三题 5分)
给了一个 二维的grid, grid[i][j] 代表 (i, j) 坐标的楼的高度,我们能从前后和左右看到两个高度的轮廓,我们的目标是增加楼的高度,但是让轮廓线不变。
Example:
Input: grid = [[3,0,8,4],[2,4,5,7],[9,2,6,3],[0,3,1,0]]
Output: 35
Explanation:
The grid is:
[ [3, 0, 8, 4],
[2, 4, 5, 7],
[9, 2, 6, 3],
[0, 3, 1, 0] ] The skyline viewed from top or bottom is: [9, 4, 8, 7]
The skyline viewed from left or right is: [8, 7, 9, 3] The grid after increasing the height of buildings without affecting skylines is: gridNew = [ [8, 4, 8, 7],
[7, 4, 7, 7],
[9, 4, 8, 7],
[3, 3, 3, 3] ]
题解:我们先计算出 top 和 left 的轮廓线,grid[i][j] 能取到的最大的高度就是 min(top[j], left[i])
class Solution {
public:
int maxIncreaseKeepingSkyline(vector<vector<int>>& grid) {
const int n = grid.size(), m = grid[].size();
vector<int> fromTop(m, ), fromLeft(n, );
for (int i = ; i < n; ++i) {
for (int j = ; j < m; ++j) {
fromTop[j] = max(fromTop[j], grid[i][j]);
fromLeft[i] = max(fromLeft[i], grid[i][j]);
}
}
int ret = ;
for (int i = ; i < n; ++i) {
for (int j = ; j < m; ++j) {
ret += min(fromTop[j], fromLeft[i]) - grid[i][j];
}
}
return ret;
}
};
【805】Split Array With Same Average(第四题 9分)
【Leetcode周赛】从contest-71开始。(一般是10个contest写一篇文章)的更多相关文章
- 【Leetcode周赛】从contest-91开始。(一般是10个contest写一篇文章)
Contest 91 (2018年10月24日,周三) 链接:https://leetcode.com/contest/weekly-contest-91/ 模拟比赛情况记录:第一题柠檬摊的那题6分钟 ...
- 【Leetcode周赛】从contest1开始。(一般是10个contest写一篇文章)
注意,以前的比赛我是自己开了 virtual contest.这个阶段的目标是加快手速,思考问题的能力和 bug-free 的能力. 前面已经有了100个contest.计划是每周做三个到五个cont ...
- 【Leetcode周赛】从contest-111开始。(一般是10个contest写一篇文章)
Contest 111 (题号941-944)(2019年1月19日,补充题解,主要是943题) 链接:https://leetcode.com/contest/weekly-contest-111 ...
- 【Leetcode周赛】从contest-41开始。(一般是10个contest写一篇文章)
Contest 41 ()(题号) Contest 42 ()(题号) Contest 43 ()(题号) Contest 44 (2018年12月6日,周四上午)(题号653—656) 链接:htt ...
- 【Leetcode周赛】从contest-51开始。(一般是10个contest写一篇文章)
Contest 51 (2018年11月22日,周四早上)(题号681-684) 链接:https://leetcode.com/contest/leetcode-weekly-contest-51 ...
- 【Leetcode周赛】从contest-81开始。(一般是10个contest写一篇文章)
Contest 81 (2018年11月8日,周四,凌晨) 链接:https://leetcode.com/contest/weekly-contest-81 比赛情况记录:结果:3/4, ranki ...
- 【Leetcode周赛】从contest-121开始。(一般是10个contest写一篇文章)
Contest 121 (题号981-984)(2019年1月27日) 链接:https://leetcode.com/contest/weekly-contest-121 总结:2019年2月22日 ...
- 【LeetCode】从contest-21开始。(一般是10个contest写一篇文章)
[LeetCode Weekly Contest 29][2017/04/23] 第17周 Binary Tree Tilt (3) Array Partition I (6) Longest Lin ...
- 【Leetcode周赛】比赛目录索引
contest 1 ~ contest 10: contest 11 ~ contest 20: contest 21 ~ contest 30 : https://www.cnblogs.com/z ...
随机推荐
- 【leetcode】402. Remove K Digits
题目如下: 解题思路:我的方法是从头开始遍历num,对于任意一个num[i],在[i+1~len(num)-1]区间内找出离num[i]最近并且小于num[i]的数num[j],如果j-i <= ...
- [原创] Delphi Win API函数 操作帮助文件 HtmlHelpA函数介绍
Delphi Win API函数 操作帮助文件 HtmlHelpA函数介绍 函数原型:HWND HtmlHelpA( HWND hwndCaller, LPCSTR pszFile, UINT uCo ...
- ht-4 hashmap特性
一.hashmap底层原理: hashmap调用默认构造方法会产生一个默认底层是长度为16的Entry数组,首先调用key的hasCode()方法来得到一个整数, int hash = hash(ke ...
- Eclipse使用maven创建SSM-web项目
1.环境准备 (1)maven:apache-maven-3.5.2,我的maven安装在D:\apache-maven-3.5.2,eclipse中maven配置如下: 先add ,添加好自己的ma ...
- Sentinel 1.7.0 发布,支持 Envoy 集群流量控制
流控降级中间件Sentinel 1.7.0版本正式发布,引入了 Envoy 集群流量控制支持.properties 文件配置.Consul/Etcd/Spring Cloud Config 动态数据源 ...
- Listary安装+破解
Listary 是 windows 下一个可以快速搜索所有程序,文件,并且可以快速启动程序和打开相应文件的这么一个工具,但这只是它的一个主要功能,还有其功能也是很屌的. 详细的介绍参考:[Listar ...
- Python3解leetcode Subtree of Another Tree
问题描述: Given two non-empty binary trees s and t, check whether tree t has exactly the same structure ...
- 循序渐进实现仿QQ界面(三):界面调色与控件自绘
本篇讲述如何进行界面调色.界面调色一般有两种方法,调色板和HSL色彩变换.调色板局限于256色,这里不采用,因此用HSL色彩变换实现.首先要了解一下什么是HSL色彩空间,完整且详尽的知识请到维基百科去 ...
- ECharts t图表组件使用心得
1.使用较多的是“柱状图”和“折线图”: 2.数据列的展示不能够直接输入字符串,正确的做法是将字符串转换成数字类型,这样在生成的图表上才会显示最大值和最小值: 3.对上 1 点的补充,数据列应该使用数 ...
- spring+JdbcTemplate简单使用(一)
目录 @ 1. 环境配置 maven(项目管理) idea(编译器) jdk1.8(Java环境) MySQL5.6(MySQL数据库) 2. 创建项目 在 idea 中创建普通的 maven 项目 ...