剑指Offer6-8

面试题6:输入一个链表的头结点,从尾到头反过来打印出每个节点的值。
利用堆栈的数据结构,将数据先存进堆里面,然后遍历堆,取出堆里面的元素放进ArrayList里面

/**这种结构铁定不是java1.8版本的,因为1.8版本的ListNode结构就直接是List<Node>,每个值是一个Node节点,并不能直接得到int val,还是说这种结构是自定义的数字链表结构?
*    public class ListNode {
*        int val;
*        ListNode next = null;
*
*        ListNode(int val) {
*            this.val = val;
*        }
*    }
*
*/
import java.util.ArrayList;
import java.util.Stack;
public class Solution {
    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
        if(listNode == null){
            ArrayList list = new ArrayList();
            return list;
        }

        Stack<Integer> stk = new Stack<Integer>();
        while(listNode != null){
         stk.push(listNode.val);
         listNode = listNode.next;
        }
        ArrayList<Integer> arr = new ArrayList<Integer>();
        while(!stk.isEmpty()){
            arr.add(stk.pop());
        } 
        return arr;
    }
}

简洁版的递归实现:

public class Solution{
    ArrayList<Integer> arrayList=new ArrayList<Integer>();
    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
        if(listNode != null){
            printListFromTailToHead(listNode.next); 
            arrayList.add(listNode.val) 
        }
        return arrayList;
    }
}

按照java 1.8版本提供的ListNode实现:

package javaOffer;

import org.jruby.ast.ListNode;
import org.jruby.ast.Node;

import java.util.ArrayList;
import java.util.Stack;

/**
 * Created by 罗浩 on 2018/1/28.
 */

public class Solution6{
    public ArrayList<Node> printListFromTailToHead(ListNode listNode) {
        ArrayList<Node> arrayList = new ArrayList<>();
        Stack<Node> stack = new Stack<>();//栈这里的实现应该用LinkedList用错了
        for ( int i = 0; i < listNode.size() ; i++) {
            stack.push(listNode.get(i));
        }
        if (!stack.isEmpty()) {
            arrayList.add(stack.pop());
        }
        return arrayList;
    }

}

**面试题7:重建二叉树
题目:输入某二叉树的前序遍历和中序遍历的结果,请重建该二叉树。假设输入的前序遍历和中序遍历中都不会出现相同的数字。**
基础知识回顾:
前序遍历:先依次打印父节点的值直到没有左子树,然后递归遍历父节点的右子树
中序遍历:从二叉树的最左子树开始打印,然后打印父节点值,在递归遍历父节点的右子树
后序遍历:先从二叉树的最左子树开始打印,然后递归遍历右子树,再打印父节点的值。
思路:根据前序序列的值将中序遍历分为左边左子树右边右子树两部分,同时根据已经分好的两部分把前序遍历也分成两部分分别作为再分的子前序序列,然后一直重复分下去。
前序遍历:{1,2,4,7,3,5,6,8}
中序遍历:{4,7,2,1,5,3,8,6}
根据前序遍历的1(root节点) 将中序遍历分为左子树{4,7,2}和右子树{5,3,8,6},然后前序遍历分为左子树前序遍历{2,4,7}和右子树前序遍历{3,5,6,8};在所分的左子树二叉树递归获取root.left,左子树递归完了从右子树部分获取root.right
代码实现:

/**
 * Definition for binary tree
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
    public TreeNode reConstructBinaryTree(int [] pre,int [] in) {
         TreeNode root=reConstructBinaryTree(pre,0,pre.length-1,in,0,in.length-1);
        return root;
    }
    //前序遍历{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6}
    private TreeNode reConstructBinaryTree(int [] pre,int startPre,int endPre,int [] in,int startIn,int endIn) {

        if(startPre>endPre||startIn>endIn)
            return null;
        TreeNode root=new TreeNode(pre[startPre]);

        for(int i=startIn;i<=endIn;i++)
            if(in[i]==pre[startPre]){
                root.left=reConstructBinaryTree(pre,startPre+1,startPre+i-startIn,in,startIn,i-1);
                root.right=reConstructBinaryTree(pre,i-startIn+startPre+1,endPre,in,i+1,endIn);
            }

        return root;
    }
}

面试题8:二叉树的下一个节点
题目:给定某一个二叉树和其中的一个节点,如何找出中序遍历的下一个节点?树中的节点除了有两个分别指向左、右的引用,还有指向其父节点的引用
思路分析:首先熟悉二叉树的中序遍历,不然没法分析清楚。从两种情况分析:
给出的节点有右子树:找第一个当前节点是父节点左孩子的节点,直到找到根节点 返回null(所给节点是最右叶子结点)

/*
public class TreeLinkNode {
    int val;
    TreeLinkNode left = null;
    TreeLinkNode right = null;
    TreeLinkNode next = null;

    TreeLinkNode(int val) {
        this.val = val;
    }
}
*/
public class Solution {
    TreeLinkNode GetNext(TreeLinkNode node)
    {
        if(node==null) return null;
        if(node.right!=null){    //如果有右子树,则找右子树的最左节点
            node = node.right;
            while(node.left!=null) node = node.left;
            return node;
        }
        while(node.next!=null){ //没右子树,则找第一个当前节点是父节点左孩子的节点
            if(node.next.left==node) return node.next;
            node = node.next;
        }
        return null;   //退到了根节点仍没找到,则返回null
    }
}
本 PPT 介绍了制药厂房中供配电系统的总体概念与设计要点,内容包括: 洁净厂房的特点及其对供配电系统的特殊要求; 供配电设计的一般原则与依据的国家/行业标准; 从上级电网到工厂变电所、终端配电的总体结构与模块化设计思路; 供配电范围:动力配电、照明、通讯、接地、防雷与消防等; 动力配电中电压等级、接地系统形式(如 TN-S)、负荷等级与可靠性、UPS 配置等; 照明的电源方式、光源选择、安装方式、应急与备用照明要求; 通讯系统、监控系统在生产管理与消防中的作用; 接地与等电位连接、防雷等级与防雷措施; 消防设施及其专用供电(消防泵、排烟风机、消防控制室、应急照明等); 常见高压柜、动力柜、照明箱等配电设备案例及部分设计图纸示意; 公司已完成的典型项目案例。 1. 工程背景与总体框架 所属领域:制药厂房工程的公用工程系统,其中本 PPT 聚焦于供配电系统。 放在整个公用工程中的位置:与给排水、纯化水/注射用水、气体与热力、暖通空调、自动化控制等系统并列。 2. Part 01 供配电概述 2.1 洁净厂房的特点 空间密闭,结构复杂、走向曲折; 单相设备、仪器种类多,工艺设备昂贵、精密; 装修材料与工艺材料种类多,对尘埃、静电等更敏感。 这些特点决定了:供配电系统要安全可靠、减少积尘、便于清洁和维护。 2.2 供配电总则 供配电设计应满足: 可靠、经济、适用; 保障人身与财产安全; 便于安装与维护; 采用技术先进的设备与方案。 2.3 设计依据与规范 引用了大量俄语标准(ГОСТ、СНиП、SanPiN 等)以及国家、行业和地方规范,作为设计的法规基础文件,包括: 电气设备、接线、接地、电气安全; 建筑物电气装置、照明标准; 卫生与安全相关规范等。 3. Part 02 供配电总览 从电源系统整体结构进行总览: 上级:地方电网; 工厂变电所(10kV 配电装置、变压
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值