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

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

Войти
Регистрация
Восстановить пароль
 
Killer_Pooh
1 / 1 / 0
Регистрация: 22.12.2009
Сообщений: 35
#1

Массивы - C++

31.05.2011, 20:07. Просмотров 353. Ответов 1
Метки нет (Все метки)

Здравствуйте, помогите решить пожалуйста задачу на языке Си.
Дан вектор, состоящий из целых чисел. Найти наиболее часто встречающийся элемент в этом массиве и вывести первое вхождение этого элемента в данный массив.

Входные данные:
Входные данные представляют собой строку, состоящую из цифр, пробелов и знаков "минус", представляющих собой корректно записанные через пробел элементы массива. Строка заканчивается символом конца строки и её длине не превышает 32000 символов.

Выходные данные:
Одно число - первое позиция первого вхождения наиболее часто встречающегося элемента в массиве.

Примечание:
В этом задании в обязательном порядке необходимо использовать функцию, получающую в качестве аргумента массив

Заранее спасибо!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.05.2011, 20:07     Массивы
Посмотрите здесь:

C++ Массивы
C++ Массивы
C++ Массивы
C++ Массивы
Массивы C++ C++
массивы C++
C++ Массивы
Массивы C++
массивы C++
Массивы C++
Массивы C++
C++ Массивы

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
asics
Freelance
Эксперт C++
 Аватар для asics
2842 / 1779 / 144
Регистрация: 09.09.2010
Сообщений: 3,842
31.05.2011, 20:15     Массивы #2
Цитата Сообщение от Killer_Pooh Посмотреть сообщение
Дан вектор, состоящий из целых чисел. Найти наиболее часто встречающийся элемент в этом массиве и вывести первое вхождение этого элемента в данный массив.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
#include <vector>
#include <algorithm>
 
size_t c(std::vector<int> &vec, const int &val){
  return std::count(vec.begin(), vec.end(), val);
}
 
int main(){
  std::vector<int> a = {1, 5, 2, 2, 5, 2, 1};
  std::cout << *std::max_element(a.begin(), a.end(), [&](const int &_x, const int &__x) -> bool{
    return c(a, _x) < c(a, __x);
  });
  return 0;
}
Yandex
Объявления
31.05.2011, 20:15     Массивы
Ответ Создать тему
Опции темы

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