我想知道这段代码有什么问题

时间:2016-03-30 14:25:21

标签: java string if-statement linked-list

我想使用if语句进行多项选择和字符串变量... 但是,我无法输入我选择的答案或字母,它只是立即输出“输入错误”,即使我还没有输入任何东西...... 我可以问这段代码有什么问题吗?

    System.out.println("Pick your choice: \na. Add Node\nb. Delete Node\nc. Insert Node");
    String letterChoice = scan.nextLine();

    if(letterChoice.equalsIgnoreCase("A")){
        System.out.println("Enter node value: ");
        int nodeValue = scan.nextInt();
        list.addNodes(nodeValue);
    }
    else if(letterChoice.equalsIgnoreCase("B")){
        System.out.println("Which node to delete? Node #: ");
        int thisNode = scan.nextInt();
        list.deleteNode(thisNode);
    }
    else if(letterChoice.equalsIgnoreCase("C")){
        System.out.println("Input node number: ");
        int thisNode = scan.nextInt();
        int prevNode = thisNode - 1;

        System.out.println("Input node value: ");
        int nodeValue = scan.nextInt();

        list.insertNode(nodeValue, prevNode);
    }
    else{
        System.out.println("Input Error");
    }

除非我改变我的代码,否则我无法从此前的问题中找到帮助......我不想,所以我不得不问......谢谢...

完整代码......

    import java.util.*;

    public class DoublyLinkedList {


        static DNode root;
        static DNode temp;
        static DNode current;


        public void addNodes(int data){

            DNode dNode = new DNode(data);

            if(root==null){

                root = dNode;
                root.previousNode = null;
                root.nextNode = null;

            }else{

                current = root;

                while(current.nextNode!=null){

                    current = current.nextNode;

                }

                current.nextNode = dNode;
                dNode.previousNode = current;
                dNode.nextNode = null;

            }

        }

        public void insertNode(int data, int after){

            DNode dNode = new DNode(data);

            int ithNode = 1;

            current = root;

            while(ithNode != after){

                current = current.nextNode;

                ithNode++;

            }

            temp = current.nextNode;

            current.nextNode = dNode;
            dNode.nextNode = temp;
            temp.previousNode = dNode;
            dNode.previousNode = current;

        }

        public void deleteNode(int nodeNumber){

            int ithNode = 1;

            current = root;

            if(nodeNumber==1){

                root = current.nextNode;
                current.nextNode = null;
                current.previousNode = null;

            }else{

                while(ithNode != nodeNumber){

                    current = current.nextNode;

                    ithNode++;

                }

                if(current.nextNode == null){

                    current.previousNode.nextNode = null;
                    current.previousNode = null;

                }else{

                    current.previousNode.nextNode = current.nextNode;
                    current.nextNode.previousNode = current.previousNode;

                }

            }

        }

        public void print(){

            current = root;

            System.out.print("The Linked List: ");

            do{

                System.out.print(" " + current.data + " ");


                current = current.nextNode;

            }while(current!=null);

        }

        public void printBackwards(){

            current = root;

            while(current.nextNode!=null){

                current = current.nextNode;

            }

            System.out.print("Inverse: ");

            do{

                System.out.print(" " + current.data + " ");

                current = current.previousNode;

            }while(current.previousNode!=null);

            System.out.print(" " + current.data + " " );

        }

        public static void main(String[] args){

            DoublyLinkedList list = new DoublyLinkedList();
            Scanner scan = new Scanner(System.in);

            String letterChoice = "";
            int nodesNum;

            System.out.print("Input number of nodes: ");
            nodesNum = scan.nextInt();

            for(int x = 1; x <= nodesNum; x++){
                System.out.print("Input value of node #" + x + ": ");
                int value = scan.nextInt(); 
                list.addNodes(value);
            }

            list.print();


            System.out.println("Pick your choice: \na. Add Node\nb. Delete Node\nc. Insert Node");
            letterChoice = scan.nextLine();

            if(letterChoice.equalsIgnoreCase("A.")){
                System.out.println("Enter node value: ");
                int nodeValue = scan.nextInt();
                list.addNodes(nodeValue);
            }
            else if(letterChoice.equalsIgnoreCase("B.")){
                System.out.println("Which node to delete? Node #: ");
                int thisNode = scan.nextInt();
                list.deleteNode(thisNode);
            }
            else if(letterChoice.equalsIgnoreCase("C.")){
                System.out.println("Input node number: ");
                int thisNode = scan.nextInt();
                int prevNode = thisNode - 1;

                System.out.println("Input node value: ");
                int nodeValue = scan.nextInt();

                list.insertNode(nodeValue, prevNode);
            }
            else{
                System.out.println("Input Error");
            }

            list.print();
            System.out.println();
            list.printBackwards();

            System.out.println();
            System.out.println("The number of DNodes in the Linked List is " + DNode.noOfLinkedList);


        }

    }


     class DNode {

        static int noOfLinkedList = 0;

        int data;

        DNode previousNode;
        DNode nextNode;

        DNode(int data){

            this.data = data;
            noOfLinkedList++;

        }

    }

感谢所有的帮助,但是我的jdk或cmd出了问题,或者没有任何帮助...或者我可能只是不清楚......看,这是我的问题...... Image of the problem

它运行,是的,但它只是跳到其输出“输入错误”的其他部分......

1 个答案:

答案 0 :(得分:0)

请记住,Scanner#nextInt方法不会消耗输入的最后一个换行符,因此在下次调用Scanner#nextLine时会消耗该换行符。

看看这个:http://docs.oracle.com/javase/7/docs/api/java/util/Scanner.html#nextLine%28%29

的QuickFix

System.out.print("Input number of nodes: ");
nodesNum = scan.nextInt();
scan.nextLine(); //this force the reading of the last newline after reading the integer...

...
System.out.println("Pick your choice: \na. Add Node\nb. Delete Node\nc. Insert Node");
final String letterChoice = scan.nextLine();