2023华为od统一考试B卷【二叉树中序遍历】

前言

博主刷的华为机考题,代码仅供参考,因为没有后台数据,可能有没考虑到的情况

如果感觉对你有帮助,请点点关注点点赞吧,谢谢你!

题目描述

思路

0.用Character数组存储树,index下标的左右子树下标是index*2+1,index*2+2

1.用一个栈来保存父亲节点:在操作{}内部的数据时入栈(也就是碰到"{"时)

2.遇到 {, 的情况就是直接是index的左子树为空,右子树存在index=index*2+2

3.遇到 { 情况,(没有和 , 连接)index的左子树index=index*2+1

4.遇到 , 的情况:如果是左右两个子树都存在,index指向左子树,index++就ok

  1. 遇到 } 出栈 index=出栈元素也就是父亲节点

  2. 遇到节点字符(字母)写入Character数组

7.中序遍历(比较简单,递归实现)

  1. 这道题难在处理字符串构建二叉树

代码

java 复制代码
import java.util.Scanner;
import java.util.Stack;

/*
a{b{d,e{g,h{,I}}},c{f}}
 */
public class Main {
    public static void main(String[] args) {
        Scanner in=new Scanner(System.in);
        String str=in.nextLine();
        Character[] arr=new Character[202];
        int index=0;
        Stack<Integer>stack=new Stack<>();
        for (int i = 0; i < str.length();i++) {
            if(str.charAt(i)=='{'){
                stack.push(index);
                if(str.charAt(i+1)==','){
                    index=index*2+2;
                }else{
                    index=index*2+1;
                }
            }else if(str.charAt(i)==','){
                if(str.charAt(i+1)!='}'&&str.charAt(i-1)!='{'){
                    index++;
                }
            }else if(str.charAt(i)=='}'){
                index=stack.peek();
                stack.pop();
            }else{
                arr[index]=str.charAt(i);
            }
        }
        ZX(arr,0);
    }
    private static void ZX(Character[] arr,int index){
        if(arr[index]==null)return;
        ZX(arr,index*2+1);
        System.out.print(arr[index]);
        ZX(arr,index*2+2);
    }
}
相关推荐
hansang_IR19 分钟前
【题解】洛谷 P4286 [SHOI2008] 安全的航线 [递归分治]
c++·数学·算法·dfs·题解·向量·点积
乐迪信息19 分钟前
乐迪信息:AI摄像机在智慧煤矿人员安全与行为识别中的技术应用
大数据·人工智能·算法·安全·视觉检测
多恩Stone1 小时前
【3DV 进阶-2】Hunyuan3D2.1 训练代码详细理解下-数据读取流程
人工智能·python·算法·3d·aigc
dragoooon341 小时前
[数据结构——lesson5.1链表的应用]
数据结构·链表
塔中妖2 小时前
【华为OD】微服务的集成测试
华为od·微服务·集成测试
惯导马工2 小时前
【论文导读】IDOL: Inertial Deep Orientation-Estimation and Localization
深度学习·算法
老姜洛克2 小时前
自然语言处理(NLP)之n-gram从原理到实战
算法·nlp
CoovallyAIHub3 小时前
基于YOLO集成模型的无人机多光谱风电部件缺陷检测
深度学习·算法·计算机视觉
CoovallyAIHub3 小时前
几十个像素的小目标,为何难倒无人机?LCW-YOLO让无人机小目标检测不再卡顿
深度学习·算法·计算机视觉
怀旧,3 小时前
【C++】19. 封装红⿊树实现set和map
linux·c++·算法