题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入 2 4 3 1
```python class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def invertTree(root): # 如果当前节点为空,直接返回 if not root: return None # 交换左右子树 root.left, root.right = root.right, root.left # 递归翻转左右子树 invertTree(root.left) invertTree(root.right) return root def preorderTraversal(root): # 先序遍历函数 if not root: return [] result = [] stack = [root] while stack: node = stack.pop() result.append(node.val) if node.right: stack.append(node.right) if node.left: stack.append(node.left) return result def buildTree(data): # 构建二叉树 if not data: return None nodes = [None if val == -1 else TreeNode(int(val)) for val in data] kids = nodes[::-1] root = kids.pop() for node in nodes: if node: if kids: node.left = kids.pop() if kids: node.right = kids.pop() return root def solve(t, test_cases): results = [] for n, d, tree_data in test_cases: # 构建树 tree = buildTree(tree_data) # 翻转树 inverted_tree = invertTree(tree) # 获取先序遍历结果 pre_order = preorderTraversal(inverted_tree) results.append(' '.join(map(str, pre_order))) return results # 读取输入 import sys input = sys.stdin.read data = input().split() index = 0 t = int(data[index]) test_cases = [] for _ in range(t): n = int(data[index + 1]) d = int(data[index + 2]) index += 3 tree_data = [] for i in range(d): row = list(map(int, data[index:index + 2 i])) index += 2 i tree_data.extend(row) test_cases.append((n, d, tree_data)) results = solve(t, test_cases) for result in results: print(result) ``` 需要注意的逻辑点: 1. 边界条件:确保在构建树时处理好 `-1` 表示的空节点。 2. 递归深度:由于树的最大层数 `d` 可以达到 13,递归调用可能较深,确保递归不会导致栈溢出。 3. 输入解析:输入数据的解析需要准确无误,特别是多组测试数据的处理,确保每一组数据的解析正确。 [2024-12-02 09:50:35 | AI写代码神器 | 613点数解答]
- [字节豆包] 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入 2 4 3 1(452点数解答 | 2024-12-02 09:49:52)208
- [阿里通义] 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入 2 4 3 1(613点数解答 | 2024-12-02 09:50:35)241
- [阿里通义] 使用c语言代码 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入(1053点数解答 | 2024-12-02 09:51:45)180
- [字节豆包] 三倍子串 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定一个十进制正整数 n n,请问可以从 n n 中截取多少种不同的子串,使得子串构成的数字是 3 3 的倍数。 例如:当 n = 1234 n=1234 时,有且仅有 3 3, 12 12, 123 123, 234 234 这四个子串是 3 3 的倍数。 输入格式 单个整数:表示输入的数字 n n 输出格式 单个整数:表示 3 3 的倍数的子串数量。 数据范围 对于 20 % 20% 的数据, 1 ≤ n ≤ 1 0 9 1≤n≤10 9 ; 对于 50 % 50% 的数据, 1 ≤ n ≤ 1 0 100 1≤n≤10 100 ; 对于 70 % 70% 的数据, 1 ≤ n ≤ 1 0 1000 1≤n≤10 1000 ; 对于 100 % 100% 的数据, 1 ≤ n ≤ 1 0 100000 1≤n≤10 100000 样例数据 输入: 95764 输出: 6 说明: 子串6,9,57,576,957,9576是3的倍数 输入: 1111 输出: 2 说(486点数解答 | 2025-08-29 11:52:55)143
- [字节豆包] 题目描述 现在给出一排共 n 只鹅的身高,李白想知道最高的鹅比其他所有鹅高多少、最矮的鹅 比其他所有鹅矮多少。 请输出这两行信息。 输入格式 输入共两行。 第一行一个整数 n 表示鹅的数目。 第二行共 n 个整数 ai(i=1,2,3...n),表示第 i 只鹅的身高。 输出格式 输出共两行。 第一行共 n 个空格隔开的整数,第 i 个整数表示序列中第 i 只鹅比最高的那只鹅要 矮多少。 第二行共 n 个空格隔开的整数,第 i 个整数表示序列中第 i 只鹅比最矮的那只鹅要 高多少。 输入输出样例 输入 #1 6 4 7 8 6 3 2 输出 #1 4 1 0 2 5 6 2 5 6 4 1 0 说明/提示 李白一共有 6 只鹅,最高的一只身高为 8,最矮的一只身高为 2,然后分别作为被减 数和减数参与身高差计算可得结果。 对于 30% 数据,保证 0≤ai≤30,1≤n≤20。 对于 100% 数据,保证 0≤ai≤1018,1≤n≤106。 用c++语言(549点数解答 | 2025-11-16 20:19:06)24
- [百度文心] c++描述 一天,一个画家在森林里写生,突然爆发了山洪,他需要尽快返回住所中,那里是安全的。 森林的地图由R行C列组成,空白区域用点“.”表示,洪水的区域用“*”表示,而岩石用“X”表示,另画家的住所用“D”表示,画家用“S”表示。 有以下几点需要说明: 1.每一分钟画家能向四个方向移动一格(上、下、左、右)。 2.每一分钟洪水能蔓延到四个方向的相邻格子(空白区域)。 3.洪水和画家都不能通过岩石区域。 4.画家不能通过洪水区域(同时也不行,即画家不能移到某个格子,该格子在画家达到的同时被洪水蔓延到了,这也是不允许的)。 5. 洪水蔓不到画家的住所。 给你森林的地图,编写程序输出最少需要花费多长时间才能从开始的位置赶回家中。 输入描述 输入第一行包含两个整数R和C(R,C<=50)。 接下来R行每行包含C个字符(“.”、“*”、“X”、“D”或“S”)。 地图保证只有一个“D”和一个“S”。 输出描述 输出画家最快安全到达住所所需的时间,如果画家不可能安全回家则输出“KAKTUS”。 用例输入 1 3 3 D.* ... .S. 用例输出 1 (1384点数解答 | 2025-03-16 17:33:49)315
- [字节豆包] 题目描述 网站注册需要有用户名和密码,编写程序以检查用户输入密码的有效性。合规的密码 应满足以下要求 :。 只能由 a∼z 之间 26 个小写字母、A∼Z 之间 26 个大写字母、0∼9 之间 10 个数字 以及 !@#$ 四个特殊字符构成。 密码最短长度 :6 个字符,密码最大长度 :12 个字符。 大写字母,小写字母和数字必须至少有其中两种,以及至少有四个特殊字符中的一 个。 输入格式 输入一行不含空格的字符串。约定长度不超过 100。该字符串被英文逗号分隔为多 段,作为多组被检测密码。 输出格式 输出若干行,每行输出一组合规的密码。输出顺序以输入先后为序,即先输入则先输 出。 输入输出样例 输入 #1 seHJ12!@,sjdkffH$123,sdf!@&12HDHa!,123&^YUhg@! 输出 #1 seHJ12!@ sjdkffH$123 说明/提示 【样例 1 解释】 输入被英文逗号分为了四组被检测密码:seHJ12!@、sjdkffH$123、sdf!@&12HDHa!、 123&^YUhg@!。其中 sdf!@&12HDHa! 长度(567点数解答 | 2025-11-26 20:44:53)21
- [字节豆包] 题目描述 输入两个整数 a , b a,b 1. 1. 对 a , b a,b之间个位数是 3 3的数字求和并输出。 2. 2. 判断这个和是不是3的倍数,如果这个数字是3的倍数,请输出: Y E S YES,否则的话输出: N O NO。 输入格式 输入包括一行,包含两个整数 a , b a,b,数字之间用空格隔开。 输出格式 输出包括两行 第一行为 a ∼ b a∼b 之间 个位数是 3 3 的数字和。 第二行 如果这个数字是3的倍数,请输出: Y E S YES,否则的话输出: N O NO。 input1 复制 1 10 output1 复制 3 YES input2 复制 4 21 output2 复制 13 NO 样例解释 对于样例 1 1: 1 ∼ 10 1∼10 之间个位数是 3 3数字有 1 1 个,是 3 3,所以第一行输出 3 3,它是 3 3的倍数,所以第二行输出: Y E S YES。 对于样例 2 2: 4 ∼ 21 4∼21 之间个位数是 3 3数字有 1 1 个,是 13 13,所以第一行输出 13 13,它不是 3 3(358点数解答 | 2025-07-12 21:48:22)180
- [字节豆包] 题目描述 十进制数字中的每一个数码可以用数位来描述。例如,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)21
- [字节豆包] 题目描述 十进制数字中的每一个数码可以用数位来描述。例如,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)28
- [字节豆包] #include<bits/stdc++.h> using namespace std; int main(){ double A,B,C; double a,b,c,d,e,x,y; cin>>a>>b>>c>>d>>e>>x>>y; A=a*x+b*y; B=c*y; C=d*y+e; double max=A; int num=1; if (B>max){ max=B; num=2; } if (C>max) { max=C; num=3; } cout<<num<<" "<<fixed<<setprecision(2)<<max<<endl; return 0; } 用语言解释代码含义(819点数解答 | 2025-11-16 19:12:58)23
- [百度文心] c++描述 小夏同学在思考一个复杂的问题: 输入 m,a,n,请输出 ( i=1 ∑ n a i )modm,即 (a+a 2 +⋯+a n )modm。 说明/提示 对于所有测试数据,保证:1≤m,a≤10 9 ,1≤n≤10 15 。 测试点编号 n a 特殊性质 1−3 ≤10 7 ≤10 9 无 4−6 ≤10 15 ≤2 无 7−10 ≤10 15 ≤10 9 m 为质数 11−20 ≤10 15 ≤10 9 无 输入描述 输入 m,a,n。 输出描述 输出 ( i=1 ∑ n a i )modm。 用例输入 1 1000 2 10 用例输出 1 46 用例输入 2 11451410 1919811 8765423561347 用例输出 2 2213137 用例输入 3 114514 9999 1000 用例输出 3 28840(911点数解答 | 2025-03-29 19:12:07)251