LeetCode周赛#209
1609. 奇偶树 #广搜 #二叉树的层次遍历
题目链接
题意
如果一棵二叉树满足下述几个条件,则可以称为奇偶树 :
二叉树根节点所在层下标为 0 ,根的子节点所在层下标为 1 ,根的孙节点所在层下标为 2 ,依此类推。
偶数下标 层上的所有节点的值都是 奇 整数,从左到右按顺序 严格递增
奇数下标 层上的所有节点的值都是 偶 整数,从左到右按顺序 严格递减
给定根节点,要求判断该二叉树是否为奇偶树
分析
BFS对于已知根节点,按深度遍历时,十分高效。这里要注意下入队列顺序是从左至右。
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
bool isEvenOddTree(TreeNode* root) {
queue<TreeNode*> myque;
myque.push(root);
int depth = 0;
while (!myque.empty()) {
int n = myque.size();
TreeNode* pre = nullptr, * cur = nullptr;//pre节点为与cur同高的左边节点
while (n--) { //将当前高度的所有节点都遍历一次
cur = myque.front(); myque.pop();
if (depth & 1) {
if (cur->val & 1) return false;
if (pre != nullptr && pre->val <= cur->val) return false;
}
else {
if (cur->val % 2 == 0) return false;
if (pre != nullptr && pre->val >= cur->val) return false;
}
if (cur->left) myque.push(cur->left);
if (cur->right) myque.push(cur->right);
pre = cur;
}
depth++;
}
return true;
}
};
1610. 可见点的最大数目 #极角 #排序 #双指针
题目链接
题意
你的位置为\((pos_x, pox_y)\),视野角度为\(angle\)。现给定一组顶点坐标\(points\)。现问你的视野中最多能看到多少个顶点。
样例

分析
感谢@前额叶没长好的讲解!
atan2(y, x)函数,取值范围为\((-\pi, +\pi]\)(你可以理解为,极径从\(-\pi\)弧度逆时针旋转至\(\pi\)弧度)。当函数返回值为正,即表示从\(x\)轴逆时针旋转的弧度,返回值为负,表示从\(x\)轴顺时针旋转的弧度。atan2(y,x)与\(arctan(y/x)\)的关系如下:\[atan2(y,x)=\begin{cases}
arctan(\frac{y}{x}) &第一象限或第四象限的点 \\
\pi+arctan(\frac{y}{x}) &第二象限的点 \\
arctan(\frac{y}{x}) &第三象限的点 \\
+\frac{\pi}{2} &y>0且x=0 \\
-\frac{\pi}{2} &y<0且x=0
\end{cases}
\]
由此我们便可利用atan2(y,x)计算\((y,x)\)的极角了,我们把点集\(points\)所有点的极角(此时为角度制)都存到一个数组中,对其从小到大排序后,每个弧度代表的点的顺序恰好\(xoy\)平面的逆时针方向,为:第三象限->第四象限->第一象限->第四象限。接着,我们通过双指针,便能找到给定区间\(angle\)下的最多点数。
但是注意,我们要求的是区间实际是一个环,还要考虑到下图中的弧\(ab\),如果直接逆时针从小到大遍历的话,就无法覆盖第二象限与第三象限之间的劣弧\(ab\)了。我们不妨再给极角数组中所有点\(+360^{\circ}\),这样就能将圆环的首尾相连了。由于我们用的是双指针,不会将之前的点重复计入。

另外,建议将角度换算为角度制而不是弧度制,弧度制太小了,容易出现精度问题(wa了8发)
const double EPS = 1e-8;
class Solution {
public:
int visiblePoints(vector<vector<int>>& points, int angle, vector<int>& location) {
vector<double> pangle;
int cnt = 0, ans = 0;
for (int i = 0; i < points.size(); i++){
double dx = location[0] - points[i][0], dy = location[1] - points[i][1];
if(dx == 0 && dy == 0) //有可能该点与位置点重合
cnt++;
else{
double tmp = 180 * atan2(dy, dx) / acos(-1.0); //求极角
pangle.push_back(tmp);
pangle.push_back(tmp + 360);
}
}
sort(pangle.begin(), pangle.end());
double ang = angle; int hi = 1;
for (int lo = 0; lo < pangle.size(); lo++){
while(hi < pangle.size() &&
(pangle[hi] - pangle[lo] < angle + EPS))
hi++;
ans = max(ans, hi - 1 - lo + 1);
}
return ans + cnt;
}
};
1611. 使整数变为0的最少操作次数 #记忆化搜索 #格雷码
题目链接
题意
给定整数$ n$,你需要重复执行多次下述操作将其转换为\(0\) :
翻转$ n $的二进制表示中最右侧位(第\(0\)位)。
如果第$ (i-1) \(位为\) 1 \(且从第\) (i-2) \(位到第\) 0 \(位都为\) 0\(,则翻转\) n \(的二进制表示中的第\) i $位。
返回将 \(n\) 转换为$ 0 $的最小操作次数。
分析
再次感谢@前额叶没长好的讲解qaq
我们观察这一组数据
100 -> 101 -> 111 -> 110 -> 010 -> 011 -> 001 -> 000
观察到 100->...->010->...->000是三个位数不同的状态,也就说在操作过程中位数是单调递减的!我们再用多组数据观察发现,要使操作次数最小,他们的操作路径都是固定方向的一条直线!同时上面三个二进制数也是位数发生改变后的首个二进制数 。
不妨设f(xxxxxx)表示将二进制xxxxxx变为0的最小操作次数。
- 当
xxxxxx形如11xxxx时,要使它位数降低,只有题目中的操作二才能做到。我们是不是应该要将后面未知的xxxx变为0000呢,即将11xxxx变为110000,从而满足操作二的执行条件,由此110000通过操作二变为010000。总的来说,就是对11xxxx->…->110000->…->010000->….->000000(只保留了关键步骤),这样的思想就是计算汉诺塔时候用到的思想!故操作次数f(11xxxx)=f(00xxxx)+1+f(010000)(f(00xxxx)表示11xxxx变为110000的操作次数,1表示110000变为010000的操作次数,f(010000)表示从010000变为000000操作次数 - 当
xxxxxx形如10xxxx时,我们就要先将0xxxx转化为10000即将10xxxx变为110000,接下来操作与上面情况相同了。操作次数即为f(10xxxx)=f(10000)-f(xxxx)+1+f(10000),(f(10000)-f(xxxx)表示将10xxxx变为110000的操作次数)
class Solution {
private:
unordered_map<int, int> f;
public:
int DFS(int n) {
if (n == 0) return 0;
if (n == 1) return 1;
if (f.count(n) > 0) return f[n];
int hiBit = 1 << 30, loBit = 1 << 29;
int ans = 0;
while (hiBit > 0) {
if (n & hiBit) {
if (n & loBit) {
ans = DFS(n ^ (hiBit | loBit)) + 1 + DFS(loBit);
break;
}
else {
ans = DFS(loBit) - DFS(n ^ hiBit) + 1 + DFS(loBit);
break;
}
}
else {
hiBit >>= 1;
loBit >>= 1;
}
}
return f[n] = ans;
}
int minimumOneBitOperations(int n) {
f.clear();
return DFS(n);
}
};
另外,题目要求的操作实际上,与格雷码的枚举基本一致,可参考此篇题解
LeetCode周赛#209的更多相关文章
- 【Leetcode周赛】从contest-111开始。(一般是10个contest写一篇文章)
Contest 111 (题号941-944)(2019年1月19日,补充题解,主要是943题) 链接:https://leetcode.com/contest/weekly-contest-111 ...
- 2017-3-12 leetcode 167 209 216
---恢复内容开始--- 对于每次开机avast喊出的“已经检测到危害”实在忍无可忍了(它只能检测到不能根除很气..)于是重装了系统,回到了win10感觉不赖. =================== ...
- 拼写单词[哈希表]----leetcode周赛150_1001
题目描述: 给你一份『词汇表』(字符串数组) words 和一张『字母表』(字符串) chars. 假如你可以用 chars 中的『字母』(字符)拼写出 words 中的某个『单词』(字符串),那么我 ...
- 【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-71开始。(一般是10个contest写一篇文章)
Contest 71 () Contest 72 () Contest 73 (2019年1月30日模拟) 链接:https://leetcode.com/contest/weekly-contest ...
- 【Leetcode周赛】从contest-81开始。(一般是10个contest写一篇文章)
Contest 81 (2018年11月8日,周四,凌晨) 链接:https://leetcode.com/contest/weekly-contest-81 比赛情况记录:结果:3/4, ranki ...
- 【Leetcode周赛】从contest-91开始。(一般是10个contest写一篇文章)
Contest 91 (2018年10月24日,周三) 链接:https://leetcode.com/contest/weekly-contest-91/ 模拟比赛情况记录:第一题柠檬摊的那题6分钟 ...
- 【Leetcode周赛】从contest-121开始。(一般是10个contest写一篇文章)
Contest 121 (题号981-984)(2019年1月27日) 链接:https://leetcode.com/contest/weekly-contest-121 总结:2019年2月22日 ...
随机推荐
- 单片机串口通信电平不匹配的解决电路,5V 3.3V串口通讯
很早的时候调试串口通讯遇到单片机和模块电压不匹配,信号无法传输,所以整理后来遇到的转换电路.1.最简单的用转换电平IC,可以去淘宝上搜索,有四路的有两路的,比如这个双向电平转换模块 2.根据接触的开发 ...
- 晚间测试13 A. Dove 打扑克 vector +模拟
题目描述 分析 这道题比较关键的一点就是要看出最终牌数的种类数不会超过 \(\sqrt{n}\) 种 知道了这个性质我们就可以用 \(vector\) 维护一个有序的序列 \(vector\) 中存放 ...
- CSS动画之过渡模块
:hover伪类选择器可以用于所有的选择器(只有在悬停时,执行选择器的属性)CSS3中新增过渡模块:transition property(属性)duration(过渡效果花费的时间)timing-f ...
- nb-iot技术能自组网吗
NB-IoT是运营商主导的网络,运营在授权频段上,LoRa运营在开放频段上,可以由企业自主建设.NB-IoT构建于蜂窝网络,只消耗大约180KHz的带宽,可直接部署于GSM网络.UMTS网络或LTE网 ...
- xadmin开发后台管理系统常见问题
Xadmin开发后台管理系统 关注公众号"轻松学编程"了解更多. 添加小头像 https://blog.csdn.net/qq_34964399/article/details/8 ...
- Servlet学习笔记(三)
目录 Servlet学习笔记(三) 一.HTTP协议 1.请求:客户端发送欸服务器端的数据 2.响应:服务器端发送给客户端的数据 3.响应状态码 二.Response对象 1.Response设置响应 ...
- Ideas and Tricks Part II
33.对于统计答案幂次的技巧 对于$x^k$,考虑其组合意义:将$k$个不同球放到$x$个不同的盒子里的方案数,直接维护不好维护,那么考虑枚举把这些球放到了哪些盒子里,最后乘上第二类斯特林数和对于的阶 ...
- JavaSE基础语法学习-异常
异常 异常指程序运行中出现的不期而至的各种状况,如:文件找不到.网络连接失败.非法参数等. 异常发生在程序运行期间,它影响了正常的程序执行流程. 比如说,你的代码少了一个分号,那么运行出来结果是提示是 ...
- Spring Cloud 整合分布式链路追踪系统Sleuth和ZipKin实战,分析系统瓶颈
导读 微服务架构中,是否遇到过这种情况,服务间调用链过长,导致性能迟迟上不去,不知道哪里出问题了,巴拉巴拉....,回归正题,今天我们使用SpringCloud组件,来分析一下微服务架构中系统调用的瓶 ...
- linux_杂记 命令
1. 查看centos版本号: lsb_release -a 2. 查看mysql服务是否开机启动: http://www.cnblogs.com/panjun-Donet/archive/2010/ ...