Java 实例 - 压栈出栈的方法实现字符串反转

以下实例演示了使用用户自定义的方法 StringReverserThroughStack() 来实现字符串反转:

/*

author by w3cschool.cc

StringReverserThroughStack.java

*/

import java.io.IOException;

public class StringReverserThroughStack {

private String input;

private String output;

public StringReverserThroughStack(String in) {

input = in;

}

public String doRev() {

int stackSize = input.length();

Stack theStack = new Stack(stackSize);

for (int i = 0; i < input.length(); i++) {

char ch = input.charAt(i);

theStack.push(ch);

}

output = "";

while (!theStack.isEmpty()) {

char ch = theStack.pop();

output = output + ch;

}

return output;

}

public static void main(String[] args)

throws IOException {

String input = "www.w3cschool.cc";

String output;

StringReverserThroughStack theReverser =

new StringReverserThroughStack(input);

output = theReverser.doRev();

System.out.println("反转前: " + input);

System.out.println("反转后: " + output);

}

class Stack {

private int maxSize;

private char[] stackArray;

private int top;

public Stack(int max) {

maxSize = max;

stackArray = new char[maxSize];

top = -1;

}

public void push(char j) {

stackArray[++top] = j;

}

public char pop() {

return stackArray[top--];

}

public char peek() {

return stackArray[top];

}

public boolean isEmpty() {

return (top == -1);

}

}

}

以上代码运行输出结果为:

反转前: www.w3cschool.cc

反转后: cc.loohcsc3w.www

java压栈重复字符串_Java 实例 – 压栈出栈的方法实现字符串反转相关推荐

  1. PAT甲级1051 Pop Sequence:[C++题解]模拟栈、判断序列是否是合法的出栈序列

    文章目录 题目分析 题目来源 题目分析 来源:acwing 分析: 题意:将1~N压栈,判断给定序列是否是合法的出栈序列. 对于序列1~N中的每个值i,先将其压入栈.然后对于它就有两种处理方法:要么压 ...

  2. 出栈(释放栈)和引用栈内数据意义不等同,和嵌套有关系但不是等同关系,局部变量进栈操作,不是局部变量自动带有进栈指令。汇编语言后局部变量操作是包含进栈操作指令PUSH和栈内地址存储数据调用,出栈。

    出栈(释放栈)和引用栈内数据意义不等同,和嵌套有关系但不是等同关系,局部变量进栈操作,不是局部变量自动带有进栈指令.汇编语言后局部变量操作是包含进栈操作指令PUSH和栈内地址存储数据调用,出栈. 2. ...

  3. 元素入栈顺序确定,共有多少种出栈顺序?----Python

    文章目录 问题描述 对栈的理解 题目的思考 python代码 卡特兰数 扩展思路 问题描述 前几天看到一个题目,假设五个元素的入栈顺序为e1.e2.e3.e4.e5,那么共有多少种出栈顺序?一时之间思 ...

  4. 【HTML】处理<br>换行符追加到前端换行无效的问题 --- html中渲染的字符串中包含HTML标签无效的处理方法,字符串中包含HTML标签被转义的问题 解决

    [HTML]处理 换行符追加到前端换行无效的问题 --- html中渲染的字符串中包含HTML标签无效的处理方法,字符串中包含HTML标签被转义的问题 解决 参考文章: (1)[HTML]处理 换行符 ...

  5. 理解——先序遍历是入栈过程,中序遍历是出栈过程

    遇到这样一道题:先序序列为a,b,c,d的不同二叉树的个数是多少? 拿到这个问题 首先,要了解到先序遍历和中序遍历都是需要用到栈,其中,先序遍历是入栈过程,中序遍历是出栈过程 然后,二叉树的先序序列和 ...

  6. java压缩文件太慢_java 解压6万个ZIP文件,如何提升速度?

    目前我使用的是org.apache.tools.zipjar包解压5015个zip文件,解压后14344个文件,耗时:669493毫秒代码:****************************** ...

  7. java数组查找指定元素_Java 实例 - 在数组中查找指定元素

    以下实例演示了如何使用 contains () 方法来查找数组中的指定元素:/* author by w3cschool.cc 文件名:Main.java */import java.util.Arr ...

  8. java char 空字符串_java判断char是否为空的方法

    java判断char是否为空的方法 发布时间:2020-06-23 11:47:02 来源:亿速云 阅读:173 作者:Leah 这篇文章将为大家详细讲解有关java判断char是否为空的方法,文章内 ...

  9. java设置子线程优先级_Java 实例 - 线程优先级设置

    Java 实例 - 线程优先级设置 以下实例演示了如何通过setPriority() 方法来设置线程的优先级: SimplePriorities.java 文件 public class Simple ...

最新文章

  1. Linux —— 目录(文件夹)及文件相关处理指令
  2. RemoveError: 'setuptools' is a dependency of conda and cannot be removed from
  3. socket_循环发送消息
  4. SpringBoot退出登录,使session失效
  5. Flink的scala+python的shell模式实验记录汇总
  6. Swing中的一些对话框
  7. 第一个express app 详细步骤
  8. 2,列表渲染指令v-for以及过滤和排序---vue教程
  9. HTML5关于上传API的一些使用(上)
  10. C++ Error: error LNK2019: unresolved external symbol
  11. KVM详解(二)——KVM安装部署
  12. 通过telegram 传递变量_Docker随时随地玩转变量
  13. MATLAB绘制椭圆
  14. 【Java基础知识 17】聊一聊同步代码块
  15. 动易CMS从word复制粘贴公式
  16. Codeforces 1071C Triple Flips 构造
  17. tplink控制上网设备_tp link无线路由器设置里的主人设备 访客网络
  18. 《信息检索》课程笔记
  19. Blue Coat 最新报告显示 移动端恶意攻击愈演愈烈
  20. JAVA学习【IDEA转中文】

热门文章

  1. vue怎么通过if跳出方法_vue多种弹框的弹出形式
  2. and型变量哲学家问题C语言,利用AND型信号量解决哲学家进餐问题,要windows下的C/C++的完整源代码程序。(五个哲学家五只筷子)...
  3. 鼠标方式自动弹出内容html,html 在一个超链接上面,鼠标移动上去时,也显示一串文字,如何实现...
  4. 45.UITableView去除分割线
  5. 统计进仓和出仓数量随时间变化的剩余数量流程图
  6. HashMap的hash()
  7. spring boot 调试 - 热部署
  8. 临时禁用自增列插入数据
  9. iphone 流媒体
  10. Android Audio代码分析2 - 函数getMinBufferSize