SearchStack <e>类型中的searchStacks(Stack <e>,E)方法不适用于参数(Stack <string>,String)</string> </e> </e>

时间:2014-09-30 01:27:11

标签: java generics stack queue

我正在尝试创建一个通用方法来搜索堆栈中的元素&#34; e&#34;使用队列并将堆栈返回到其原始状态。

但我一直收到错误&#34; SearchStack类型中的searchStacks(Stack,E)方法不适用于参数(Stack,String)&#34;当我打电话给方法&#34; searchingStacks&#34;

请帮助,提前谢谢。

import java.util.Stack; 
import java.util.Stack.* ;   

public class SearchStack<E> extends Object {



    public static void main (String [] args ) {

        Stack < String > test = new Stack () ;

        for (int i = 0 ; i < 5 ; i ++ ) {

            test.push("a" + i ) ; }


        System.out.println (test.toString()) ;

        System.out.println ( searchingStacks (test , "a3") ) ;
        }


    public boolean searchingStacks (Stack<E> s1 , E e) {

        boolean result = false ; 
        Queue <E> temp = new LinkedQueue () ;


        while (s1.isEmpty() == false )
        {
            if (s1.peek() == e ) { result = true ; }
            temp.enqueue(s1.pop());
            }

        while (temp.isEmpty() == false ){

            s1.push( temp.dequeue() ) ;
            }

        while (! s1.isEmpty()  ) { temp.enqueue(s1.pop());}
        while (! temp.isEmpty() ) { s1.push(temp.dequeue()) ; }



        return result ;}

}

1 个答案:

答案 0 :(得分:0)

main方法是静态方法,因此您无法直接在那里调用searchingStacks。 调用实例方法需要该类的实例。

public class SearchStack<E> extends Object
{

public static void main(String[] args)
{
    SearchStack<String> ss = new SearchStack<String>();

    Stack<String> stack = new Stack<String>();

    for (int i = 0; i < 5; i++)
    {

        stack.push("a" + i);
    }

    System.out.println(stack.toString());

    System.out.println(ss.searchingStacks(stack, "a3"));
}
...
}