树的左视图(Java)

问题描述:

二叉树的节点按照从上到下,从左到右,从1开始编号,其中空着的节点用“#”表示。输出树的左视图,如:
输入:1 2 3 # 4 5 6 # # # # 7 8
输出:1 2 4 7
在这里插入图片描述

public class LeftViewTree {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int i= 0; //当前多少层
        int j = 0; //当前层的第几个节点
        boolean flag = false; //是否找到当层的第一个非空节点

        while(in.hasNext()) {
            i = i+1;
            j = 1;
            flag = false;

            while(j <= Math.pow(2,i-1)) {
                if(!in.hasNext())
                    return;
                String s = in.next();
                if(flag == false && !s.equals("#")){
                    System.out.print(s + " ");
                    flag = true;

                }
                j++;
            }

        }

    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值