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 C

1 Answer

0 votes
#include <stdio.h>
#include <limits.h>
 
int getTheSecondSmallest(int arr[], int size) { 
    int first, second; 
 
    first = second = INT_MAX; 
    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 == INT_MAX) 
        return -1;
         
    return second; 
} 
 
int main(void) 
{ 
    int arr1[] = {34, 3, 8, 2, 9, 4, 6}; 
    printf("%d\n", getTheSecondSmallest(arr1, sizeof(arr1)/sizeof(arr1[0]))); 
     
    int arr2[] = {1, 1, 2, 1, 1}; 
    printf("%d\n", getTheSecondSmallest(arr2, sizeof(arr2)/sizeof(arr2[0]))); 
     
     
    int arr3[] = {5, 5, 5, 5, 5, 5, 5}; 
    printf("%d\n", getTheSecondSmallest(arr3, sizeof(arr3)/sizeof(arr3[0]))); 
     
    return 0; 
} 
 
 
 
/*
run:
 
3
2
-1
 
*/

 



answered May 31, 2020 by avibootz
edited May 31, 2020 by avibootz

Related questions

1 answer 109 views
1 answer 123 views
1 answer 99 views
2 answers 165 views
1 answer 122 views
2 answers 122 views
1 answer 103 views
...