2017-09-20 112 views
-1

如果我進入98意味着它會顯示6位。如何查找數組中某個特定數字的位置?

public class OddEven { 
    public static void main(String args[]) { 
     int[] numbers = new int[] { 14, 23, 67, 10, 76, 5, 98, 13, 110 }; 
     for (int i = 0; i < numbers.length; i++) { 
      if(numbers[i]==14) 
       System.out.println(numbers[i]+"position 0"); 
      else 
       System.out.println(numbers[i]+"no. not in the list"); 
     } 
    } 
} 
+1

請刪除javascript標記。 –

+1

那麼,有什麼問題? –

+0

只是返回我,你會有位置 – cralfaro

回答

0

首先,這是好事,有這樣的事情,作爲可測性等目的的獨立的功能。這也使得代碼更清晰。其次,如果你是通過循環,你可能不希望做system.out.println內環路

所以,你想是這樣的:

public class IndexLookup { 
    int[] numbers = new int[] { 14, 23, 67, 10, 76, 5, 98, 13, 110 }; 
    public int indexOf(int query) { 
     for (int I = 0; I < numbers.length; i++) { 
      if (numbers[I] == query){ 
       return I; 
      } 
     } 
     return -1 
    } 
    public static void main(String[] args) { 
     if (indexOf(98) == -1) { 
      System.out.println("Not in list"); 
     } else { 
      System.out.printf("Found %d at position %d%n", 98, indexOf(98)); 
     } 
} 
+0

非常感謝你....我得到了答案.... –

0

只需使用的代碼如下,將打印預期的結果如果你不想陣列考慮0的位置,你可以隨時增加i值以我+ 1中出放聲明「如果」存在的條件「的」循環內:-)

  boolean found = false; 
      int[] numbers = { 14, 23, 67, 10, 76, 5, 98, 13, 110 }; 
      Scanner sc=new Scanner(System.in); 

      System.out.println("Enter the number to search"); 
      int num =sc.nextInt(); 
      for (int i = 0; i < numbers.length; i++) { 
       if(numbers[i]==num){ 
        System.out.println(numbers[i]+" position "+i); 
        found =true; 
        break; 
       } 
      } 
      if(!found){ 
       System.out.println("Unable to find the Entered Number in the array"); 
      } 
相關問題