import java.io.BufferedReader;
import java.io.InputStreamReader;
//用栈来实现一个字符串逆序算法
/**
* 数据结构:栈
*/
class StackW{
private int maxSize;
private char[] stackArray;
private int top;
public StackW(int max){
maxSize = max;
stackArray = new char[maxSize];
top = -1;
}
public void push(char c){
stackArray[++top] = c;
}
public char pop(){
return stackArray[top--];
}
public char peek(){
return stackArray[top];
}
public boolean isEmpty(){
return (top == -1);
}
public boolean isFull(){
return (top == maxSize);
}
}
/**
* 反转类
*/
class Reverser{
private String input;
private StringBuilder output;
public Reverser(String in){
input = in;
output = new StringBuilder();
}
/**
* 使用定义的栈来进行字符串的反转
* @return
*/
public String doReverse(){
int stackSize = input.length();
StackW s = new StackW(stackSize);
for(int j= 0;j<stackSize;j++){
char c = input.charAt(j);
s.push(c);
}
while(!s.isEmpty()){
char ch = s.pop();
output.append(ch);
}
return output.toString();
}
}
public class WordReverse {
public static void main(String[] args) throws Exception {
String input, output;
while(true){
System.out.println("Enter a string");
System.out.flush();
input = getString();
if(input.equals(""))
break;
Reverser re = new Reverser(input);
output = re.doReverse();
System.out.println("reversed:"+output);
}
}
/**
* 从键盘读字符串
* @return
* @throws Exception
*/
public static String getString() throws Exception{
InputStreamReader isr = new InputStreamReader(System.in);
BufferedReader br = new BufferedReader(isr);
String s = br.readLine();
return s;
}
}
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步