繁体   English   中英

使用堆栈反转字符串?

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM