2017-02-16 12 views
0

Итак, моя проблема в том, что я завис над вторым заявлением. Я должен разрешить пользователю вводить несколько строк ввода (все заданные одновременно), а цикл while заканчивается сам после того, как все входные данные используются следующим образом:Взять сразу несколько строк ввода

Ограничение скорости 40 миль/ч, но вы собирались более 65

99 бутылок ...

код использует только первый вход затем закрывается, когда я использую scan.hasNextLine он остается в бесконечном цикле

public static void main(String[] args) throws IOException { 
    Scanner scan = new Scanner(System.in); 
    Scanner scan2 = new Scanner(System.in); 
    List<Integer> numbers = new ArrayList<>(); 
    Pattern p = Pattern.compile("([-+]?[0-9]+(?:\\.[0-9]+)?)"); 

    String phrase; 
    String[] tens = { "Ten", "Twenty", "Thirty", "Fourty", "Fifty", "Sixty", "Seventy", "Eighty", "Ninety" }; 
    String[] teens = { "Eleven", "Twelve", "Thirteen", "Fourteen", "Fifteen", "Sixteen", "Seventeen", "Eighteen", 
      "Nineteen" }; 
    String[] ones = { "", "One", "Two", "Three", "Four", "Five", "Six", "Seven", "Eight", "Nine" }; 

    phrase = scan.nextLine(); 

    Matcher m = p.matcher(phrase); 
    while (m.find()) { 
     numbers.add(Integer.parseInt(m.group())); 

    } 
    // Solve 

    while (There is another line of input) {// i need some help here!!! 
     for (int i = 0; i < numbers.size(); i++) { 

      if (numbers.get(i) >= 20) { 

       if (numbers.get(i) % 10 == 0) { 
        phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), 
          tens[((numbers.get(i) - numbers.get(i) % 10)/10) - 1]); 
       } else { 

        phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), 
          (tens[((numbers.get(i) - numbers.get(i) % 10)/10) - 1] + "-" 
            + ones[numbers.get(i) % 10])); 
       } 

      } else if (numbers.get(i) < 20 && numbers.get(i) > 10) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), teens[(numbers.get(i) % 10) - 1]); 

      } else if (numbers.get(i) < 10 && numbers.get(i) > 0) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), ones[numbers.get(i)]); 
      } else if (numbers.get(i) == 10) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), "Ten"); 
      } else if (numbers.get(i) == 0) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), "Zero"); 
      } 

     } 

    } 
    System.out.println(phrase); 
} 
+0

Вы говорите: «Я должен позволить пользователю поместить несколько строк ввода (все дано в то же время)». Итак, в консоль вставляется многострочный фрагмент текста, и вы нажимаете enter, правильно? Вы пытались сделать еще один 'scan.nextLine()' сразу после 'hasNextLine()'? –

+0

Игнорируйте мои предыдущие промахи, вот что подумать: http://stackoverflow.com/a/23713487/5629413 –

+0

Если мой ответ помог вам, вы можете принять его как ответ. –

ответ

0

Сделайте это.

public static void main(String[] args) throws IOException { 
    Scanner scanner = new Scanner(System.in); 
    Pattern p = Pattern.compile("([-+]?[0-9]+(?:\\.[0-9]+)?)"); 

    String[] tens = {"Ten", "Twenty", "Thirty", "Fourty", "Fifty", "Sixty", "Seventy", "Eighty", "Ninety"}; 
    String[] teens = {"Eleven", "Twelve", "Thirteen", "Fourteen", "Fifteen", "Sixteen", "Seventeen", "Eighteen", 
     "Nineteen"}; 
    String[] ones = {"", "One", "Two", "Three", "Four", "Five", "Six", "Seven", "Eight", "Nine"}; 

    String phrase = null; 
    while (scanner.hasNextLine()) { 
     phrase = scanner.nextLine(); 
     // if input is an empty line, exit from loop 
     if (phrase.isEmpty()) { 
      break; 
     } 

     List<Integer> numbers = new ArrayList<>(); 
     Matcher m = p.matcher(phrase); 
     while (m.find()) { 
      numbers.add(Integer.parseInt(m.group())); 
     } 

     for (int i = 0; i < numbers.size(); i++) { 
      if (numbers.get(i) >= 20) { 
       if (numbers.get(i) % 10 == 0) { 
        phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), 
          tens[((numbers.get(i) - numbers.get(i) % 10)/10) - 1]); 
       } else { 
        phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), 
          (tens[((numbers.get(i) - numbers.get(i) % 10)/10) - 1] + "-" 
          + ones[numbers.get(i) % 10])); 
       } 
      } else if (numbers.get(i) < 20 && numbers.get(i) > 10) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), teens[(numbers.get(i) % 10) - 1]); 
      } else if (numbers.get(i) < 10 && numbers.get(i) > 0) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), ones[numbers.get(i)]); 
      } else if (numbers.get(i) == 10) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), "Ten"); 
      } else if (numbers.get(i) == 0) { 
       phrase = phrase.replaceAll(Integer.toString(numbers.get(i)), "Zero"); 
      } 
     } 
     System.out.println(phrase); 
    } 
} 

Выход

The speed limit is 40 mph, but you were going over 65 
The speed limit is Fourty mph, but you were going over Sixty-Five 
99 bottles of ... 
Ninety-Nine bottles of ... 
Смежные вопросы