数据结构栈,利用栈实现字符串逆序输出

该博客展示了如何使用Java数据结构栈来实现字符串的逆序输出。通过创建一个Stack类并使用其push和pop方法,从输入的字符串中逐字符压栈,然后反向弹出,从而达到逆序打印的效果。
摘要由CSDN通过智能技术生成
package none002;
import java.util.*;
import java.io.*;
//数据结构栈,利用栈实现字符串逆序输出
public class ReverseApp {

	/**
	 * @param args
	 */
	public static void main(String[] args) throws IOException{
		// TODO Auto-generated method stub

		InputStreamReader isr=new InputStreamReader(System.in);
		BufferedReader br=new BufferedReader(isr);
		Stack  sx=new Stack(20);
		
		System.out.println("please input words or sentence you want to reverse:");
		String s=br.readLine();
		for(int i=0;i<s.length();i++){
			sx.push(s.charAt(i));
		}
		System.out.println("The result is that:");
		while(!sx.isEmpty()){
			System.out.print(sx.pop());
		}
	}

}
class Stack{
	int items;
	char[] arrayStack;
	int s;
	Stack(int  max){
		s=max;
		arrayStack=new char[s];
		items=-1;
	}
	public void push(char value){
		if(items==s-1) System.out.println("栈已经等于最大值了。");
		else arrayStack[++items]=value;
	}
	public char pop(){
		return arrayStack[items--];
	}
	public boolean isEmpty(){
		return items==-1;
	}
	public char peek(){
		if(items==-1) return 0;
		else return arrayStack[items];
	}
	public boolean isFull(){
		return items==s-1;
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值