2012-03-29 84 views
0

好吧,所以我需要繼續獲取用戶輸入,直到它們輸入0.我需要將它們存儲在一個數組中並打印出最小值。但它一直給我最後輸入的數字,而不是排序,並獲得列表中的最小值。這是我迄今爲止所做的。使用遞歸尋找最小值

import java.io.*; 
import java.util.*; 

public class FindingMin 
{ 

    public static void main(String[] args) throws IOException 
    { 
     int[] Numbers = new int[100]; 
     int minimum = 0; 
     int InputParser; 
     String input= "1"; 


     try 
     { 
      InputStreamReader stream = new InputStreamReader (System.in); 
      BufferedReader scan = new BufferedReader(stream); 

      InputParser = Integer.parseInt(input); 

      while(InputParser != 0) 
      { 
       input = scan.readLine(); 
       InputParser = Integer.parseInt(input); 
       for(int i = 0;i<Numbers.length;i++) 
       { 
        if(InputParser == 0) 
        { 
         InputParser = 0; 
        } 
        else 
        Numbers[i] = InputParser; 

       } 

      } 

      minimum = findingMin(Numbers,Numbers[0],Numbers.length-1); 
      System.out.println("The minimum number is "+minimum); 


     } 
     catch(NumberFormatException exception) 
     { 
      System.out.println("Please enter integers only"); 
     } 

    } 

    public static int findingMin(int[] list, int start, int end) 
    { 
      if (start == end) 
       return list[start]; 
      else 
      { 
      int Min = findingMin(list, start, end-1); 
      if (Min < list[end]) 
       return list[end]; 
      else 
       return Min; 
      } 


    } 
} 

任何建議將不勝感激!

+3

你爲什麼要在'Numbers [0]'中傳入start int?也許可以嘗試先改變它。 – 2012-03-29 23:00:08

+1

這是功課嗎? – 2012-03-29 23:02:03

+0

請注意與命名,間距,縮進,花括號等相一致 - 當存在一些慣例時,難以推理代碼。 – 2012-03-29 23:03:19

回答

2

那是因爲你有一個額外的循環:

while(InputParser != 0) 
{ 
     input = scan.readLine(); 
     InputParser = Integer.parseInt(input); 
     for(int i = 0;i<Numbers.length;i++) 
     { 
      if(InputParser == 0) 
      { 
       InputParser = 0; 
      } 
      else 
       Numbers[i] = InputParser; // <-- you set all numbers 
              //  to the last input here 

     } 

} 

正確的版本是:

int i = 0; 
while(InputParser != 0) 
{ 
     input = scan.readLine(); 
     InputParser = Integer.parseInt(input); 
     if(InputParser == 0) 
     { 
      InputParser = 0; 
     } 
     else 
     { 
      Numbers[i] = InputParser; 
      i++; 
     } 
} 

此外,調用方法應該是:

minimum = findingMin(Numbers,0,Numbers.length-1); 

minimum = findingMin(Numbers,Numbers[0],Numbers.length-1);