java中栈Stack类操作

	/**
	 * Stack类
	 * 栈:桶型或箱型数据类型,后进先出,相对堆Heap为二叉树类型,可以快速定位并操作
	 * Stack<E>,支持泛型
	 * public class Stack<E> extends Vector<E>
	 * Stack的方法调用的Vector的方法,被synchronized修饰,为线程安全(Vector也是)
	 * Stack methods:
	 * push : 把项压入堆栈顶部 ,并作为此函数的值返回该对象
	 * pop : 移除堆栈顶部的对象,并作为此函数的值返回该对象 
	 * peek : 查看堆栈顶部的对象,,并作为此函数的值返回该对象,但不从堆栈中移除它
	 * empty : 测试堆栈是否为空 
	 * search : 返回对象在堆栈中的位置,以 1 为基数 
	 * */

操作代码为下:

package ca.map;

import java.util.Stack;

public class StackX {
	public static void main(String[] args) {
		stackMethod();
	}
	//stack operate
	public static void stackMethod(){
		//定义一个Integer泛型的Stack
		Stack<Integer> stack = new Stack<Integer>();
		System.out.println("新建栈stack是否为空 : "+(stack.empty() ? "空" : stack.size()));
		//push : 把项压入堆栈顶部,返回值泛型指定的类型
		//此处将1到5压入栈中
		stack.push(1);
		stack.push(2);
		stack.push(3);
		stack.push(4);
		stack.push(5);
		System.out.println("将1到5按顺序压入栈中后为:"+stack);
		//empty : 测试堆栈是否为空,size() == 0,返回值boolean
		System.out.println("值为1~5的栈中stack是否为空 : "+(stack.empty() ? "空" : stack.size()));
		//search : 返回对象在堆栈中的位置,以 1 为基数,参数:search(Object o) ,返回值int
		int oStack = stack.search(3);
		System.out.println("查找栈stack中对象3的位置elementId为 : "+oStack);
		//peek : 查看堆栈顶部的对象,但不从堆栈中移除它,返回值泛型指定的类型
		int topElement =stack.peek();
		System.out.println("查看stack的栈顶元素为 : "+topElement);
		System.out.println("peek操作stack后为 : "+stack);
		//pop : 移除堆栈顶部的对象,并作为此函数的值返回该对象,返回值泛型指定的类型
		int oRemove = stack.pop();
		System.out.println("移除stack栈顶的元素为 : "+oRemove);
		System.out.println("pop操作移除stack栈顶元素后为 : "+stack);
	}
}

输出为:

新建栈stack是否为空 : 空
将1到5按顺序压入栈中后为:[1, 2, 3, 4, 5]
值为1~5的栈中stack是否为空 : 5
查找栈stack中对象3的位置elementId为 : 3
查看stack的栈顶元素为 : 5
peek操作stack后为 : [1, 2, 3, 4, 5]
移除stack栈顶的元素为 : 5
pop操作移除stack栈顶元素后为 : [1, 2, 3, 4]

Stack的toString()方法继承自Vector的toString()方法;

Vector的toString()方法super.toString()继承自AbstractList继承自AbstractCollection的toString()方法:

代码为:

    public String toString() {
        Iterator<E> i = iterator();
	if (! i.hasNext())
	    return "[]";

	StringBuilder sb = new StringBuilder();
	sb.append('[');
	for (;;) {
	    E e = i.next();
	    sb.append(e == this ? "(this Collection)" : e);
	    if (! i.hasNext())
		return sb.append(']').toString();
	    sb.append(", ");
	}
    }

若集合为空,返回  []

若集合不为空则 [  加上迭代元素 加上 , 最后集合无元素加上 ] eg:[1, 2, 3, 4]



  • 20
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaStack是一个后进先出(LIFO)的数据结构,它继承了Vector,因此它可以使用Vector的所有方法。以下是Stack的基本代码实现示例: ```java import java.util.Stack; public class Main { public static void main(String[] args) { Stack<String> stack = new Stack<>(); // 添加元素到栈顶 stack.push("Java"); stack.push("is"); stack.push("awesome"); // 获取栈顶元素并删除 String element = stack.pop(); System.out.println("Removed Element: " + element); // 获取栈顶元素但不删除 element = stack.peek(); System.out.println("Element on top: " + element); // 获取栈的大小 int size = stack.size(); System.out.println("Stack size: " + size); // 判断栈是否为空 boolean isEmpty = stack.isEmpty(); System.out.println("Is stack empty?: " + isEmpty); } } ``` 在上面的示例中,我们创建了一个Stack对象,然后使用push()方法向栈中添加元素。我们还演示了如何使用pop()方法获取并删除栈顶元素,以及使用peek()方法获取但不删除栈顶元素。最后,我们使用size()方法获取栈的大小,使用isEmpty()方法判断栈是否为空。 ### 回答2: 在Java中,可以通过引入`java.util.Stack`来实现堆栈(Stack)的功能。 首先,需要创建一个`Stack`实例: ```java Stack<Integer> stack = new Stack<>(); ``` 然后,可以使用以下方法来操作堆栈: 1. `push(element)`:将一个元素推入堆栈的顶部。 ```java stack.push(1); stack.push(2); stack.push(3); ``` 2. `pop()`:移除并返回堆栈顶部的元素。 ```java int topElement = stack.pop(); System.out.println("Top element: " + topElement); // 输出:Top element: 3 ``` 3. `peek()`:返回堆栈顶部的元素,但不移除它。 ```java int topElement = stack.peek(); System.out.println("Top element: " + topElement); // 输出:Top element: 3 ``` 4. `empty()`:判断堆栈是否为空。 ```java boolean isEmpty = stack.empty(); System.out.println("Is stack empty? " + isEmpty); // 输出:Is stack empty? false ``` 5. `search(element)`:返回元素在堆栈中的位置(从顶部开始计算,第一个元素的位置为1)。 ```java int position = stack.search(2); System.out.println("Position of element 2: " + position); // 输出:Position of element 2: 2 ``` 注意:在使用`pop()`和`peek()`方法时,需先判断堆栈是否为空,否则可能会产生异常。 以上是使用`Stack`实现堆栈功能的基本操作。除此之外,还可以通过继承`Stack`来创建自定义的堆栈,以满足特定的需求。 ### 回答3: JavaStack是一种特殊的数据结构,它遵循先进后出(Last In First Out,LIFO)的原则。在Java中,可以通过使用内置的Stack来实现该数据结构。 首先,我们需要导入Stack的包:`import java.util.Stack;` 然后,我们可以创建一个Stack的实例:`Stack<Integer> stack = new Stack<>();`,这个例子中,我们创建了一个存储整数型数据的Stack对象。 接下来,我们可以使用Stack提供的方法来操作栈,比如: 1. `push(item)`:将元素压入栈顶。例如,`stack.push(5);`将整数5压入栈顶。 2. `pop()`:从栈顶弹出一个元素,并返回弹出的元素。例如,`int poppedItem = stack.pop();`将栈顶元素弹出,并赋值给变量poppedItem。 3. `peek()`:返回栈顶元素,但不将其弹出。例如,`int topItem = stack.peek();`将栈顶元素赋值给变量topItem,但不将其从栈中移除。 4. `isEmpty()`:判断栈是否为空。返回值为布尔型,如果栈为空则返回true,否则返回false。 5. `size()`:返回栈中元素的个数。 下面是一个完整的使用Stack实现栈的示例代码: ```java import java.util.Stack; public class StackExample { public static void main(String[] args) { Stack<Integer> stack = new Stack<>(); stack.push(5); stack.push(10); stack.push(15); System.out.println("栈是否为空:" + stack.isEmpty()); System.out.println("栈的大小:" + stack.size()); int topItem = stack.peek(); System.out.println("栈顶元素:" + topItem); int poppedItem = stack.pop(); System.out.println("弹出的元素:" + poppedItem); System.out.println("栈的大小:" + stack.size()); } } ``` 以上代码中,我们首先将数字5、10和15依次压入栈中,然后通过一些方法来操作栈。最后,我们打印出栈中的元素个数和弹出的元素。 这就是使用Java中的Stack实现栈的简单示例。通过使用Stack,我们可以轻松地实现栈的各种操作

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值