就地移动栈数据

题目:将堆栈S1中的元素移至堆栈S2,元素顺序不能改变.只能使用一些非数组 变量作为辅助空间.

1.用Java实现,首先使用链表LinkedList构造栈数据结构.

import java.util.LinkedList;
public class CharStack {
  private LinkedList<Character> storage = new LinkedList<Character>();
  /** 入栈 */
  public void push(char v) {
    storage.addFirst(v);
  }
  /** 出栈,但不删除 */
  public char peek() {
    return storage.getFirst();
  }
  /** 出栈 */
  public char pop() {
    return storage.removeFirst();
  }
  /** 栈是否为空 */
  public boolean empty() {
    return storage.isEmpty();
  }
  /** 打印栈元素 */
  public String toString() {
    return storage.toString();
  }
}

时间: 2024-08-12 19:05:04

就地移动栈数据的相关文章

如何成为全栈数据科学家?

Warald指出:统计.编程.商业嗅觉三项全能的全栈数据科学家非常罕见.如果欠缺这三项中的1-2项,但是还是想成为全栈数据科学家,还有可能吗?答曰:当然.除了读书,你还可以在工作当中继续学习.不断提高.那么,该如何加强背景?该选择加入什么样的公司(或者说团队)?Warald给出一些建议. 首先感受一下自己喜欢多快的步伐,喜欢把事情做的多么细致.网络创业公司代表快+准确率不太高的极端,制药公司代表慢+极其准确的极端.即使都在互联网创业公司范围,不同产品的公司也对步伐要求不同,值得好好体会一下. 其

java虚拟机 jvm 栈数据区

java栈帧还是需要一些数据支持常量池的解析.正常方法的返回和异常的处理.大部分的java字节码指令需要进行常量池的访问,在栈帧数据区中保存着访问常量池的指针,方便程序访问java常量池.如下图所示:   当函数返回或者程序出现异常的时候,jvm虚拟机必须恢复调用者函数的栈帧,并且让调用者函数继续执行.什么意思呢?举一个通俗的例子: a()调用b()当b()返回的时候肯定继续让a()继续执行对吧.b()抛出异常的时候a()肯定也需要处理对吧. 对于异常的处理,jvm是如何处理的呢?虚拟机肯定必须

Java中堆与栈的区别

栈与堆都是Java用来在RAM中存放数据的地方.与C++不同,Java自动管理栈和堆,程序员不能直接地设置栈或堆. Java的堆是一个运行时数据区,类的对象从中分配空间.这些对象通过new.newarray.anewarray和multianewarray等指令建立,它们不需要程序代码来显式的释放.堆是由垃圾回收来负责的,堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,因为它是在运行时动态分配内存的,Java的垃圾收集器会自动收走这些不再使用的数据.但缺点是,由于要在运行时动态分配

关于Java栈与堆的思考

1.栈(stack)与堆(heap)都是Java用来在Ram中存放数据的地方.与C++不同,Java自动管理栈和堆,程序员不能直接地设置栈或堆. 2.栈的优势是,存取速度比堆要快,仅次于直接位于CPU中的寄存器.但缺点是,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性.另外,栈数据可以共享,详见第3点.堆的优势是可以动态地分配内存大小,生存期也不必事先告诉编译器,Java的垃圾收集器会自动收走这些不再使用的数据.但缺点是,由于要在运行时动态分配内存,存取速度较慢. 3.Java中的数据类型有

Android开发:内存机制分析——堆和栈

  1.dalvik的Heap和Stack 这里说的只是dalvik java部分的内存,实际上除了dalvik部分,还有native.这个以后再说. 开发:内存机制分析--堆和栈-"> 下面针对上面列出的数据类型进行说明,只有了解了我们申请的数据在哪里,才能更好掌控我们自己的程序. 2.对象实例数据 实际上是保存对象实例的属性,属性的类型和对象本身的类型标记等,但是不保存实例的方法.实例的方法是属于数据指令,是保存在Stack里面,也就是上面表格里面的类方法. 对象实例在Heap中分配好

仅用递归函数和栈逆序一个栈

package stackAndQueue; import java.util.Stack; import org.junit.Test; /** * 仅用递归函数和栈逆序一个栈:ReverseStack[2] * * [一个栈依次压入1.2.3,将栈转置,使栈顶到栈底依次是1.2.3,只能用递归函数,不能借用额外的数据结构包括栈] * * 算法思想:两个递归函数(getAndRemoveBottom.reverse) * * @author xiaofan */ public class Re

JVM学习(2)——技术文章里常说的堆,栈,堆栈到底是什么,从os的角度总结

俗话说,自己写的代码,6个月后也是别人的代码--复习!复习!复习!涉及到的知识点总结如下: 堆栈是栈 JVM栈和本地方法栈划分 Java中的堆,栈和c/c++中的堆,栈 数据结构层面的堆,栈 os层面的堆,栈 JVM的堆,栈和os如何对应 为啥方法的调用需要栈 属于月经问题了,正好碰上有人问我这类比较基础的知识,无奈我自觉回答不是有效果,现在深入浅出的总结下: 前一篇文章总结了:JVM 的内存主要分为3个分区 堆区(Heap)-- 只存对象(数组)本身(引用类型的数据),不存基本类型和对象的引用

Java中堆内存和栈内存详解

Java把内存分成两种,一种叫做栈内存,一种叫做堆内存. 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个变量时,java就在栈中为这个变量分配内存空间,当超过变量的作用域后,java会自动释放掉为该变量分配的内存空间,该内存空间可以立刻被另作他用. 堆内存用于存放由new创建的对象和数组.在堆中分配的内存,由java虚拟机自动垃圾回收器来管理.在堆中产生了一个数组或者对象后,还可以在栈中定义一个特殊的变量,这个变量的取值等于数组或者对象在堆内存

深度剖析Java变量栈&amp;amp;对象堆

Java把内存分成两种,一种叫做栈内存,一种叫做堆内存 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个变量时,java就在栈中为这个变量分配内存空间,当超过变量的作用域后,java会自动释放掉为该变量分配的内存空间,该内存空间可以立刻被另作他用. 堆内存用于存放由new创建的对象和数组.在堆中分配的内存,由java虚拟机自动垃圾回收器来管理.在堆中产生了一个数组或者对象后,还可以在栈中定义一个特殊的变量,这个变量的取值等于数组或者对象在堆内存中