How can we find second maximum from array efficiently?

前端 未结 16 1192
Happy的楠姐
Happy的楠姐 2020-12-25 14:39

Is it possible to find the second maximum number from an array of integers by traversing the array only once?

As an example, I have a array of five integers from whi

16条回答
  •  刺人心
    刺人心 (楼主)
    2020-12-25 15:12

    #include 
    using namespace std;
    
    int main() {
    
       int  max = 0;
        int sec_Max = 0;
    
        int array[] = {81,70,6,78,54,77,7,78};
    
        int loopcount = sizeof(array)/sizeof(int);
    
        for(int i = 0 ; i < loopcount ; ++i)
        {
    
            if(array[i]>max)
            {
                sec_Max = max;
                max = array[i];
            }
    
            if(array[i] > sec_Max && array[i] < max)
            {
                sec_Max = array[i];
            }
        }
    
        cout<<"Max:" << max << " Second Max: "<

提交回复
热议问题