Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/18: Рейтинг темы: голосов - 18, средняя оценка - 5.00
3 / 3 / 0
Регистрация: 23.05.2012
Сообщений: 195

найти значение третьего по величине элемента массива

20.09.2012, 17:11. Показов 3702. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
найти значение третьего по величине элемента массива размерность массива 200
диапазон значений 0-100

Добавлено через 1 час 11 минут
помогите очень нужно
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.09.2012, 17:11
Ответы с готовыми решениями:

Найти значение 3-го по величине элемента и значение всех элементов массива, которые его превышают, заменить на найденное значение
Работа с массивами:

Найти значение 3-го по величине элемента массива
Задание Объявить массив целых чисел и заполнить его значениями, введенных с клавиатуры. Диапазон значений его элементов заданы в...

Найти значение 3-го по величине элемента и значения всех элементов массива, которые его превышают, заменить на найденное значение
Найти значение 3-го по величине элемента и значения всех элементов массива, которые его превышают, заменить на найденное значение ...

5
Псевдослучайный
1946 / 1146 / 98
Регистрация: 13.09.2011
Сообщений: 3,215
20.09.2012, 17:15
Обычный поиск максимума вы написать в состоянии? Здесь тоже самое, но сравнивать надо не с одним, а с тремя сохраняемыми значениями, и сдвигать замещаемые значения ниже.
1
154 / 138 / 34
Регистрация: 23.05.2009
Сообщений: 275
20.09.2012, 17:26
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include <iostream>
#include <algorithm>
#include <ctime>
#include <iterator>
#include <functional>
 
using namespace std;
 
struct RandGen
{
   int border;
   RandGen(int i):border(i){};
   int operator()(){return rand() % border;}
};
 
int main()
{
   srand(time(NULL));
   const size_t szArray = 200;
   int arr[szArray] = {0};
   generate_n(arr, szArray, RandGen(100));
   cout<<"Generated array:\n";
   copy(arr, arr + szArray, ostream_iterator<int>(cout, " "));
   sort(arr, arr + szArray, greater<int>());
   cout<<"\nValue of the 3rd largest element is :"<<arr[2]<<endl;
   return 0;
}
1
 Аватар для soon
2554 / 1319 / 178
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
20.09.2012, 17:32
Лучший ответ Сообщение было отмечено как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
#include <array>
#include <algorithm>
#include <functional>
 
int main()
{
    std::array<int, 10> a{4, 2, 7, 1, 8, 0, 3, 5, 9, 6};
    std::partial_sort
    (
        a.begin(),
        a.begin() + 3,
        a.end(),
        std::greater<decltype(a)::value_type>()
    );
    std::cout << a[2] << std::endl;
    return 0;
}
Добавлено через 5 минут
Логичнее запихнуть в set, пожалуй.
3
 Аватар для igorrr37
2889 / 2036 / 992
Регистрация: 21.12.2010
Сообщений: 3,787
Записей в блоге: 9
20.09.2012, 21:16
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <iomanip>
#include <algorithm>
 
int main ()
{
    std::size_t const size = 200;
    int arr[size];
    srand(time(0));
    std::cout << "Array:\n";
    for(int i = 0; i < size; ++i)
    {
        arr[i] = rand() % 101;
        std::cout << std::setw(4) << std::left << arr[i] << "  ";
    }
    std::sort(arr, arr + size);
    std::cout << "\n\nSorted array:\n";
    for(int i = 0; i < size; ++i)
    {
        std::cout << std::setw(4) << std::left << arr[i] << "  ";
    }
    int* pUnique = std::unique(arr, arr + size);
    if(pUnique - arr >= 3)
    {
        std::cout << "\n\nThird largest element is " << *(pUnique - 3) << std::endl;
    }
    return 0;
}
1
1 / 1 / 1
Регистрация: 09.02.2013
Сообщений: 18
29.05.2013, 17:05
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#define n 200
int main()
{
  int mas[n],zn,i,j,k, max1,max2,max3,x;
  for(i=0;i<n;++i){
    mas[i] = 0+rand()%100;
    printf("%3d ",mas[i]);}
    printf("\n");
    printf("\n");
    getch(); 
  max1 = mas[0];
  max2 = mas[0];
  max3 = mas[0];
  for(i=0;i<n;i++){
  if (mas[i]>max1){max1=mas[i];}
}
printf("max1 %3d\n",max1);
for(i=0;i<n;i++){
if((mas[i]>max2)&&(mas[i]<max1)){max2=mas[i];}
}
printf("max2 %3d\n",max2);
for(i=0;i<n;i++){
if((mas[i]>max3)&&(mas[i]<max2)){max3=mas[i];}
}
printf("max3 %3d\n",max3);
 
for(i=0;i<n;i++){
if(mas[i]>max3){mas[i]=max3;}
printf("%3d ",mas[i]);
}
 max1 = mas[0];
 for(i=0;i<n;i++){
 if (mas[i]>max1){max1=mas[i];}
}
printf("max1 %3d\n",max1);
 
 
getch();                                                     
return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.05.2013, 17:05
Помогаю со студенческими работами здесь

Вывод третьего по величине элемента второй половины массива
Добрый день, срочно нужно решение этой задачки Буду весьма признателен за оказанную помощь &gt;&lt; Массив должен состоять из 100...

Найти значение третьего положительного элемента массива
алгоритм, который находит и выводит значение 3-го положительного элемента массива (если из массива вычеркнуть все неположительные элементы,...

В чем может быть ошибка? Нахождение третьего по величине элемента во второй половине массива
Читала, что для массивов нужно грамотно выделять память, эффективней всего динамическую. Честно говоря, не знаю, правильно ли я это...

Функция поиска третьего по величине элемента списка
Здравствуйте! Знаю как найти максимальный элемент списка, но в силу своего недавнего знакомства с LISPом, не получается переделать данную...

Найти значение 3-го по величине элемента
Помогите, пожалуйста!!! Нужен код C#. Объявить массив целых чисел и заполнить его случайными значениями. Размер массива 200,диапазон...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru