腾讯精选50题—Day9题目88,89,104
刷题的第九天~~~一定可以的!
1. 题目88 合并两个有序数组
(1) 题目描述

(2) 思路
因为vector1长度完全可以放得下,那么直接从vector1的m-1位置和vector2的n-1位置比较,将大的放在vector1的m+n-1位置上即可。
(3) 题解
class Solution {
public:
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
int p1 = m - 1;
int p2 = n - 1;
int end = m + n - 1;
while (p1 >= 0 || p2 >= 0)
{
if (p1 < 0)
{
nums1[end--] = nums2[p2--];
}
else if (p2 < 0)
{
return;
}
else if (nums1[p1] >= nums2[p2])
{
nums1[end] = nums1[p1];
end--;
p1--;
}
else {
nums1[end] = nums2[p2];
end--;
p2--;
}
}
}
};
结果:

时间复杂度:
O
(
m
+
n
)
O(m+n)
O(m+n)
空间复杂度:
O
(
1
)
O(1)
O(1)
2. 题目89 格雷编码
(1) 题目描述

(2) 思路
位运算~再分析。
(3) 题解
class Solution {
public:
vector<int> grayCode(int n) {
vector<int> result;
for (int i = 0; i < (1 << n); i++)
{
result.push_back(i ^ i >> 1);
}
return result;
}
};
结果:

时间复杂度:
O
(
2
n
)
O(2^n)
O(2n)
空间复杂度:
O
(
1
)
O(1)
O(1)
3. 题目104 二叉树深度
(1) 题目描述

(2) 思路
美妙的二叉树,递归呀呀呀呀呀呀~
(3) 题解
class Solution {
public:
int maxDepth(TreeNode* root) {
int result = Travel(root);
return result;
}
int Travel(TreeNode* root) {
if (!root)
return 0;
else {
return (max(Travel(root->left), Travel(root->right))+1);
}
}
};
结果:

时间复杂度:
O
(
n
)
O(n)
O(n) n为二叉树的结点数
空间复杂度:
O
(
h
e
i
g
h
t
)
O(height)
O(height) height为二叉树的高度
这篇博客分享了三道腾讯精选编程题的解题思路和代码实现,包括如何合并两个有序数组、生成格雷编码以及计算二叉树的最大深度。解题方法涉及排序、位运算和递归等技巧,适合提升编程能力。
1192

被折叠的 条评论
为什么被折叠?



