Предмет: Информатика, автор: MrMiner1

Язык: C++

Дано:

Неупорядоченный массив arr из n натуральных чисел.

Индекс j (1<=j<=n)

Требуется найти такое число, которое при упорядоченном по убыванию массиве находилось на arr[j-1].

Запрещено создавать новые и упорядочивать старый массив.


Макрой: В чем сложность ввести элементы, а потом по заданом индексе, который вводит юзер вывеси элемент?
MrMiner1: В конце условия было написано: "не создавать новые массивы и не упорядочивать старый". Также требуется вывести элемент массива, который бы был
в упорядоченном по убыванию массиве с индексом (j-1)
MrMiner1: Все это в условии описано
Макрой: Допустим у вас размерность 5
Макрой: j-1 это 0 либо 1 либо 2 либо 3 либо 4 - индексы элементов
MrMiner1: Да
MrMiner1: Допустим массив размерностью 5
Элементы: {2, 1, 5, 3, 4}
Вывести j=3
Выводится 3 т.к. оно является третьим по уменьшению величины начиная с наибольшего элемента массива. Или при работе через упорядоченный по убыванию массив (чего делать нельзя по условию) - {5, 4, 3 ,2, 1}, элемент массива с индексом (j-1) равен 3.
Макрой: У меня код готов
Макрой: В C++ уже
Макрой: У меня массив не упорядочен и при вводе индекса пользователем выводится элемент массива

Ответы

Автор ответа: srzontmp
0

#include <iostream>

using namespace std;

int main() {

 int n,j,mnt,mn,mx;

 cout<<"n = "; cin>>n;

 int arr[n];

 cout<<"array: "; cin>>arr[0];

 mn=arr[0]; mx=mn;  

 for (int i=1; i<n; i++) {

    cin>>arr[i];

    if (arr[i]<mn) mn=arr[i];

    if (arr[i]>mx) mx=arr[i];

 }

 mnt=mn;  

 cout<<"j = "; cin>>j;

 for (int i=2; i<=j; i++) {

    mn=mx;

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

       if ((arr[k]>mnt) && (arr[k]<mn)) mn=arr[k];

    mnt=mn;

 }

 cout<<mn<<endl;    

 system("pause");

 return 0;

}

Ввод - вывод:

n = 10

array: 11 -5 15 -8 13 -10 19 36 5 9

j = 5

9



srzontmp: Приведенный вариант программы для массива, упорядоченного по возрастанию. Для массива, упорядоченного по убыванию нужно изменить строки, вместо переменной mnt, переменная mxt - строка 4. Изменяются строки от mnt=mn; на следующие: mxt=mx;
cout<<"j = "; cin>>j;
for (int i=2; i<=j; i++) {
mx=mn;
for (int k=0; k if ((arr[k]mx)) mx=arr[k];
mxt=mx;
}
cout<
srzontmp: Да, этот сайт в комментариях обрезает символы. Должна быть строка if (( arr[k] < mxt) и (arr[k] > mx)) mx = arr[k];
srzontmp: Выводить значение переменной mx cout<
srzontmp: Опять обрезал символы "<<"
Похожие вопросы
Предмет: Математика, автор: ivan0po0pov1904