Самый большой и второй по величине число в массиве C++
Я написал код в C++ для поиска большой и второй по величине элемент в массиве. Код работает нормально, но проблема в местоположении второго по величине номера не обновляется. Хотя значение второго по величине числа верно, но его местоположение неверно.
#include<iostream>
using namespace std;
void main()
{
int DATA[10];
int largestNumber, secondLargestNumber, loc1, loc2;
cout << "Enter 10 numbers of array DATA" << endl;
for (int i = 0; i < 10; i++)
{
cin >> DATA[i];
}
largestNumber = DATA[1];
secondLargestNumber = DATA[2];
loc1 = 1;
loc2 = 2;
if (largestNumber < secondLargestNumber)
{
largestNumber = DATA[2];
secondLargestNumber = DATA[1];
}
for (int i = 2; i < 10; i++)
{
if (DATA[i]>largestNumber)
{
secondLargestNumber = largestNumber;
largestNumber = DATA[i];
loc1 = i;
}
else if (DATA[i]>secondLargestNumber)
{
secondLargestNumber = DATA[i];
loc2 = i;
}
}
cout << "Largest Number with location :"<<largestNumber<<" "<<loc1 << endl;
cout << "Second Largest Number location :" << secondLargestNumber<<" "<<loc2 << endl;
cin.get();
cin.get();
}
в случае 'DATA [я]> largestNumber' вы должны добавить' LOC2 = LOC1; '' Перед LOC1 = i': каждый раз, когда вы назначаете 'secondLargestNumber', вы должны назначить' loc2'. – Franck
Обратите внимание, что вам не нужно сохранять значения, достаточно позиций. Это значительно упростит код – Slava