profile
Опубликовано 6 лет назад по предмету Информатика от stellka99

С++.
Дано количество элементов n, и сам массив а[i]. Нужно найти 2 максимальных числа и вывести их сумму.

например n=5, a[i]= 1 2 3 4 5, sum=4+5=9
n=5, a[i]= 1 2 3 4 4, sum=4+4=8.
помогите исправить код)

  1. Ответ
    Ответ дан Giammy

    #include <iostream>

    using namespace std;

    int main() {

    int n,max0=0,ind=0,max1= -2147483647;

    /* n - размер массива, max0 - первый максимальный элемент, ind - индекс первого максимального , max1 - второй максимальный элемент */

    cin >> n;

    int *a = new int[n]; // указатель на динамический массив типа int и размера n.

    for (int i = 0; i < n; i++)

     if ((cin >> a[i], a[i]) > max0 || i == 0) {  

     /*(cin >> a[i], a[i]) - присваивание число массиву и сразу же проверка его на максимум. */

     /* Обязательное условие i == 0, тк max0 может быть и отрицательным, поэтому в любом случае  при первой итерации максимумом будет первый элемент.*/

      max0 = a[i];

      ind = i;

     }

    for (int i = 0; i < n; i++)

     if (i != ind && a[i] > max1) max1 = a[i];  

    /* поиск второго максимума, обязательное условие (i != ind) */

    cout << max0 + max1;

    delete[] a; // удаление из памяти массив a

       return 0;

    }

    1. Ответ
      Ответ дан Giammy
      То есть вы предлагаете в цикл пихать префиксный инкремент?
    2. Ответ
      Ответ дан DigitalAnnihilator
      Ага, почитайте, что бы не позорится потом
    3. Ответ
      Ответ дан DigitalAnnihilator
      К слову о константах, скорее всего компилятор так и будет видеть тип - как целочисленную константу, вопрос другой - это magic number в классическом его понимании, не пишите такое, это ошибка, а не вкусовщина, а то знаете, можно много чего делать не тем местом и не тем способом, но от этого лучше ничего не станет
    4. Ответ
      Ответ дан Giammy
      В случае i++ сперва выполняется тело цикла, а потом изменяется значение счётчика, мне это и нужно было.
    5. Ответ
      Ответ дан DigitalAnnihilator
      Могу вам подсказать - в теме вы все еще не разобрались
Самые новые вопросы