Write a Java method, smallestIndex, that takes as its parameters an int array, and returns the index of the (last occurrence of the) smallest element in the array. Write a program to test your method. Use the following array values: {10 5 15 12 3 16 25 42 3 30}

Respuesta :

Answer:

  1. public class Main {
  2.    public static void main(String[] args) {
  3.        int testArray [] = {10,5,15,12,3,16,25,42,3,30};
  4.        int minIndex = smallestIndex(testArray);
  5.        System.out.println(minIndex);
  6.    }
  7.    public static int smallestIndex(int [] arr){
  8.        int smallest = arr[0];
  9.        int result=0;
  10.        for(int i=1; i < arr.length; i++){
  11.            if(arr[i] <= smallest){
  12.                smallest = arr[i];
  13.                result = i;
  14.            }
  15.        }
  16.        return result;
  17.    }
  18. }

Explanation:

Firstly, we define a method smallestIndex that take one integer array (Line 9).

We create a variable smallest and another variable result to hold the value of smallest number in the array and its index position. We tentatively set the first element of the array as smallest (Line 10-11).

Next, create a for loop to traverse through the array elements starting with index-1 and then check if the current element is smaller or equal to the current smallest value. If so set the current element to smallest variable and set the current index to result variable (Line 14-16).

After the loop return the result (Line 19).

In the main program, we test the method using the sample array and print out the result (Line 4-6). We shall get 8 which is the index position where the last occurrence of the  smallest element found in the array.