0
import java.util.Scanner;
public class Tester {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
char c = 'x';
Queue q1 = new Queue();
Stack s1 = new Stack();
s1.push('#');
Queue q2 = new Queue();
q1.enqueue('#');
while (c != '#') {
System.out.println("Enter a character: ");
c = input.next().charAt(0);
q1.enqueue(c);
}
while (c != '#') {
c = (char) q1.dequeue();
if (!operator(c)) {
q2.enqueue(c);
}
}
q1.print(q1);
System.out.println();
q2.print(q2);
}
public static boolean operator(char c) {
char op = 'x';
boolean isOperator;
switch (op) {
case '*':
case '/':
case '^':
case '+':
case '-':
isOperator = true;
break;
default:
isOperator = false;
break;
}
return isOperator;
}
}
キューのq1にいくつかの文字を入力し、 't a#、それは文字が演算子でない限りq1からデキューしてq2にエンキューする必要があります。 しかし、q1の私の演算子はどれも、デキューされてq2にエンキューされていません。これは20行目から23行目で起こっているはずです。文字がオペレータであるかどうかをチェックすることにより、あるキューから別のキューにキューをデキューできない
は私がコードの先頭に#をエンキューので、それが助けないと思います。 – tbadam
試しましたか?あなたは条件でq1ではない 'c'をチェックしています! – granmirupa
はい、それでも結果は印刷され、すべてがq1に残ります。 – tbadam