找出数组中至少有大两个元素的元素(C++)


假设我们有一个包含 n 个数字的数组。我们要在数组中找到至少有大 两个元素的所有元素。如果数组为 A = [2, 8, 7, 1, 5],则结果为 [2, 1, 5]

要解决此问题,我们将找到第二大元素,然后打印所有小于或等于第二大值的所有元素。

示例

#include<iostream>
using namespace std;
void searchElements(int arr[], int n) {
   int first_max = INT_MIN, second_max = INT_MIN;
   for (int i = 0; i < n; i++) {
      if (arr[i] > first_max) {
         second_max = first_max;
         first_max = arr[i];
      } else if (arr[i] > second_max)
         second_max = arr[i];
   }
   for (int i = 0; i < n; i++)
   if (arr[i] < second_max)
   cout << arr[i] << " ";
}
int main() {
   int arr[] = { 2, 9, 1, 7, 5, 3, 17};
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << "Elements are: ";
   searchElements(arr, n);
}

输出

Elements are: 2 1 7 5 3

更新日期:2019 年 12 月 18 日

284 次查看

开启您的 事业

完成课程,获得认证

开始
广告