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,950 questions

51,892 answers

573 users

How to find the largest three elements in a vector with C++

2 Answers

0 votes
#include <iostream>
#include <algorithm> 
#include <vector>

int main()
{
    std::vector<int> v = { 5, 2, 9, 6, 12, 7, 8, 3, 1, 0 };
    
    partial_sort(v.begin(), v.begin() + 3, v.end(), std::greater<int>());
 
    for(auto const& n : v)
        std::cout << n << " ";
        
    std::cout << "\nfirst = " << v[0] << "\n";
    std::cout << "second = " << v[1] << "\n";
    std::cout << "third = " << v[2] << "\n";

    return 0;
}



/*
run:
       
12 9 8 2 5 6 7 3 1 0 
first = 12
second = 9
third = 8
       
*/

 

 



answered Dec 2, 2021 by avibootz
0 votes
#include <iostream>
#include <vector>
#include <climits>
 
void print3largest(std::vector<int> v) { 
    int size = v.size();
    if (size < 3) { 
        std::cout << "vector size < 3"; 
        return; 
    } 
     
    int first, second, third; 
    
    third = first = second = INT_MIN;
 
    for (int i = 0; i < size ; i ++) { 
        if (v[i] > first) { 
            third = second; 
            second = first; 
            first = v[i]; 
        } 
        else if (v[i] > second) { 
            third = second; 
            second = v[i]; 
        } 
        else if (v[i] > third) 
            third = v[i]; 
    } 
    std::cout << "The three largest elements are: " << first << " " << second << " " << third; 
} 
    
    
int main() 
{ 
    std::vector<int> v = { 5, 2, 9, 6, 12, 7, 8, 3, 1, 0 };

    print3largest(v); 
     
    return 0; 
} 
 
 
 
 
/*
run:
      
The three largest elements are: 12 9 8
      
*/

 



answered Dec 2, 2021 by avibootz

Related questions

1 answer 160 views
1 answer 176 views
1 answer 284 views
1 answer 166 views
...