作为c++开发,求二叉树的翻转
二叉树的翻转是指将二叉树的左右子树交换位置。以下是一个简单的C++实现: ```cpp struct TreeNode { int val; TreeNode *left; TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) {} }; TreeNode* invertTree(TreeNode* root) { if (root == NULL) { return NULL; } TreeNode* temp = root->left; root->left = invertTree(root->right); root->right = invertTree(temp); return root; } ``` 在这个实现中,我们首先检查根节点是否为空。如果为空,我们直接返回NULL。否则,我们交换根节点的左右子树,然后递归地对左右子树进行翻转。 [2023-11-09 00:45:35 | AI写代码神器 | 164点数解答]
相关提问
- [字节豆包] 题目描述 十进制数字中的每一个数码可以用数位来描述。例如,503 的个位为 3,十位为 0,百位为 5。对其进行数位翻转,就是将最高位变为最低位,而最低位变为最高位。503 翻转后的结果为 305。 小 A 定义了「第二数位」。十进制数从低位到高位,每两个数码构成一个「第二数位」,最高位不足两个数码的,用前导零补齐。例如,12345 将被划分为 01 23 45,共三个「第二数位」。 类似的,「第二数位」翻转,就是将最高位的「第二数位」变为最低位的「第二数位」,而最低位的「第二数位」变为最高位的「第二数位」。「第二数位」内的数码顺序不变。 给出整数 n,请对其进行「第二数位」翻转。翻转后输出的十进制整数不应包含前导零。 输入格式 一行一个整数 n 输出格式 输出一行一个整数,表示对 n 「第二数位」翻转后的结果。 输入样例1 123456 输出样例1 563412 用c语言(523点数解答 | 2025-11-10 19:54:57)64
- [字节豆包] 题目描述 十进制数字中的每一个数码可以用数位来描述。例如,503 的个位为 3,十位为 0,百位为 5。对其进行数位翻转,就是将最高位变为最低位,而最低位变为最高位。503 翻转后的结果为 305。 小 A 定义了「第二数位」。十进制数从低位到高位,每两个数码构成一个「第二数位」,最高位不足两个数码的,用前导零补齐。例如,12345 将被划分为 01 23 45,共三个「第二数位」。 类似的,「第二数位」翻转,就是将最高位的「第二数位」变为最低位的「第二数位」,而最低位的「第二数位」变为最高位的「第二数位」。「第二数位」内的数码顺序不变。 给出整数 n,请对其进行「第二数位」翻转。翻转后输出的十进制整数不应包含前导零。 输入格式 一行一个整数 n 输出格式 输出一行一个整数,表示对 n 「第二数位」翻转后的结果。 输入样例1 123456 输出样例1 563412 说明/提示 用c++语言(462点数解答 | 2025-11-10 20:30:20)89
- [百度文心] 作为**工程师,作为**工程师如何做到不漏测?(386点数解答 | 2023-11-09 18:25:11)328
- [阿里通义] 作为c++开发,什么是c++的面向对象编程?(285点数解答 | 2023-11-09 00:36:11)289
- [阿里通义] 作为c++开发,什么是虚函数?(289点数解答 | 2023-11-09 00:36:17)238
- [阿里通义] 作为c++开发,什么是多线程?(64点数解答 | 2023-11-09 00:36:19)236
- [阿里通义] 作为c++开发,什么是死锁?(61点数解答 | 2023-11-09 00:36:21)255
- [阿里通义] 作为c++开发,什么是虚拟内存?(79点数解答 | 2023-11-09 00:36:23)259
- [阿里通义] 作为c++开发,什么是udp协议?(171点数解答 | 2023-11-09 00:36:26)228
- [阿里通义] 作为c++开发,什么是tcp协议?(165点数解答 | 2023-11-09 00:36:30)230
- [阿里通义] 作为c++开发,什么是http协议?(121点数解答 | 2023-11-09 00:36:33)244
- [阿里通义] 作为c++开发,什么是数据库索引?(189点数解答 | 2023-11-09 00:36:37)216