Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
wowan30002
2 / 2 / 0
Регистрация: 23.05.2012
Сообщений: 194
#1

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

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

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

Добавлено через 1 час 11 минут
помогите очень нужно
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.09.2012, 17:11
Здравствуйте! Я подобрал для вас темы с ответами на вопрос найти значение третьего по величине элемента массива (C++):

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

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

Найти значение и индексы максимального по абсолютной величине элемента матрицы - C++
Дана прямоугольная матрица b. Найти в ней значение и индексы максимального по абсолютной величине элемента. Если таких элементов несколько,...

Вычислить произведение в состав которого войдет ненулевое значение каждого третьего элемента массива - C++
Дан одномерный числовой массив. Вычислить произведение в состав которого войдет ненулевое значение каждого третьего элемента массива.

Определить значение второго по величине элемента в последовательности чисел - C++
Дана последовательность натуральных чисел (одно число в строке), завершающаяся числом 0. Определите значение второго по величине элемента в...

Цикл while: Определить значение второго по величине элемента в этой последовательности - C++
2)Последовательность состоит из различных натуральных чисел и завершается числом 0. Определите значение второго по величине элемента в этой...

5
NoMasters
Псевдослучайный
1762 / 1105 / 73
Регистрация: 13.09.2011
Сообщений: 3,141
20.09.2012, 17:15 #2
Обычный поиск максимума вы написать в состоянии? Здесь тоже самое, но сравнивать надо не с одним, а с тремя сохраняемыми значениями, и сдвигать замещаемые значения ниже.
1
Andsteadur
153 / 137 / 3
Регистрация: 23.05.2009
Сообщений: 275
20.09.2012, 17:26 #3
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
2541 / 1306 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
20.09.2012, 17:32 #4
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
1647 / 1275 / 133
Регистрация: 21.12.2010
Сообщений: 1,932
Записей в блоге: 7
20.09.2012, 21:16 #5
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
vlad310362
1 / 1 / 0
Регистрация: 09.02.2013
Сообщений: 18
29.05.2013, 17:05 #6
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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.05.2013, 17:05
Привет! Вот еще темы с ответами:

Определение 3го по величине элемента массива - C++
В соревнованиях по бегу принимают участие N спортсменов (3 ≤ N ≤ 1000). Результаты забега занесены в массив по порядку номеров участников....

определить номер наименьшего по абсолютной величине элемента массива - C++
определить номер наименьшего по абсолютной величине элемента массива А на С++

В массиве X(N) найти значение максимального элемента массива и найти, сколько таких элементов. - C++
В массиве X(N) найти k1 - количество элементов массива, расположенных после минимального элемента и k2 - количество элементов массива,...

Найти номер и значение наибольшего кратного 5 элемента массива P(12) - C++
Найти номер и значение наибольшего кратного 5 элемента массива P(12)


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

Или воспользуйтесь поиском по форуму:
6
Yandex
Объявления
29.05.2013, 17:05
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru