[英]Using stacks to reverse string?
到目前为止,这是我的代码,我需要创建一个反向字符串,以便input =“ hello”将输出=“ olleh” ...我的错误出现在代码的push和pop部分中。 我不能使用StringBuffer。 错误是-
线程“主”中的异常java.lang.Error:未解决的编译问题:l无法解决l无法解决
在E.reverse(E.java:10)在E.main(E.java:17)
你能帮忙吗?
public class Rev {
public static String reverse(String s) {
MyStack st = new MyStack();
while (!s.isEmpty()) {
String k = st.toString();
st.push(s);
}
while (!s.isEmpty()) {
String p = st.pop();
return s;
}}
public static void main(String[] args) {
System.out.println(reverse("hello"));
}
}
一种简单的方法是:
private Stack s = new Stack();
public void reversestack( String str )
{
for(int j = 0; j < str.length(); j++)
{
s.push( str.charAt( j ) );
}
while(s.isEmpty() != true)
{
System.out.println(s.pop());
}
}
这样尝试如何:-
public class StringReverse {
public static void main(String [] args){
Scanner scanner = new Scanner(System.in);
String str = "";
Stack<String> stack = new Stack<String>();
System.out.println("Enter a string to be reversed: ");
str = scanner.nextLine();
for (int i=0;i<str.length();i++){
stack.push(str.substring(i,i+1));
}
String strrev = "";
while(!stack.isEmpty()){
strrev += stack.pop();
}
System.out.println("Reverse of the string \"" + str + "\" is: \"" + strrev + "\"");
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.