剑指OFFER 链表 + 二叉树

请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

剑指OFFER 链表 + 二叉树

实现的想法就是:创建一个string字符串,然后将原来字符串一个一个字符提取出来,先判断是不是空格,是空格就替换,不是空格就直接使用append方法添加到新的字符串当中去

 

输入一个链表,按链表从尾到头的顺序返回一个ArrayList。

 

剑指OFFER 链表 + 二叉树

 

和上面的题解法有相似之处,这里需要逆序输出ArrayList。是一个先进后出的数据结构,所以用的是栈。也是取出来然后放进去的思路

 

另外一种使用递归的思想,利用的是虚拟机自带的栈,“每个方法在执行时都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用直至执行完毕的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程”

剑指OFFER 链表 + 二叉树

 

 

先补充一下数的基础知识

二叉树的序遍历:左右

二叉树的序遍历:左

二叉树的序遍历:左右

根据中序遍历和前序遍历可以确定二叉树,具体过程为:

  1. 根据前序序列第一个结点确定根结点
  2. 根据根结点在中序序列中的位置分割出左右两个子序列
  3. 对左子树和右子树分别递归使用同样的方法继续分解

例如:

前序序列{1,2,4,7,3,5,6,8} = pre
中序序列{4,7,2,1,5,3,8,6} = in

  1. 根据当前前序序列的第一个结点确定根结点,为 1
  2. 找到 1 在中序遍历序列中的位置,为 in[3]
  3. 切割左右子树,则 in[3] 前面的为左子树, in[3] 后面的为右子树
  4. 则切割后的左子树前序序列为:{2,4,7},切割后的左子树中序序列为:{4,7,2};切割后的右子树前序序列为:{3,5,6,8},切割后的右子树中序序列为:{5,3,8,6}
  5. 对子树分别使用同样的方法分解

 

输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。

 

剑指OFFER 链表 + 二叉树

 

剑指OFFER 链表 + 二叉树

 

copyOfRange :左闭右开

剑指OFFER 链表 + 二叉树

剑指OFFER 链表 + 二叉树

 

 

用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。

 

剑指OFFER 链表 + 二叉树