Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,955 questions

51,897 answers

573 users

How to find the second smallest elements in an array in Java

1 Answer

0 votes
import java.io.*; 

public class MyClass {
    static int getTheSecondSmallest(int arr[]) { 
        int first, second, size = arr.length; 
     
        first = second = Integer.MAX_VALUE; 
        for (int i = 0; i < size ; i ++) { 
            if (arr[i] < first) { 
                second = first; 
                first = arr[i]; 
            } 
            else if (arr[i] < second && arr[i] != first) 
                second = arr[i]; 
        } 
        if (second == Integer.MAX_VALUE) 
            return -1;
             
        return second; 
    } 
    public static void main(String args[]) {
        int arr1[] = {34, 3, 8, 2, 9, 4, 6}; 
        System.out.println(getTheSecondSmallest(arr1));
     
        int arr2[] = {1, 1, 2, 1, 1}; 
        System.out.println(getTheSecondSmallest(arr2));
     
        int arr3[] = {5, 5, 5, 5, 5, 5, 5}; 
        System.out.println(getTheSecondSmallest(arr3));
    }
}



/*
run:

3
2
-1

*/

 



answered May 31, 2020 by avibootz

Related questions

1 answer 123 views
1 answer 98 views
2 answers 165 views
1 answer 109 views
1 answer 115 views
1 answer 112 views
...