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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 28, средняя оценка - 4.86
Spray1
0 / 0 / 0
Регистрация: 07.12.2011
Сообщений: 34
#1

Подсчитать количество различных по значению элементов в массиве - C++

06.03.2012, 10:58. Просмотров 4705. Ответов 5
Метки нет (Все метки)

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

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

Подсчитать количество различных элементов - C++
Подсчитать количество различных элементов в каждой из строк двумерного массива. Определить функцию подсчета различных элементов.

Подсчитать для двух массивов количество разных по значению элементов - C++
Помогите пожалуйста, ооочень надо, срочненько)))) Составить программу, которая подсчитывает для массива А и В количество разных по...

Подсчитать количество различных элементов в очереди и вывести их на экран - C++
1. Подсчитать число различных элементов в очереди и вывести их на экран 2. 3. На контрольной были эти задачи. Нужно их решить....

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

Найти количество различных элементов в массиве - C++
Найти количество различных элементов в массиве.

5
dimcoder
Полярный
466 / 438 / 68
Регистрация: 11.09.2011
Сообщений: 1,136
06.03.2012, 11:04 #2
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
#include <cstdlib>
#include <iostream>
 
using namespace std;
 
int main(int argc, char *argv[])
{
    int x[20];
    int k = 0;
    bool f;
    for (int i = 0; i < 20; i++)
        cin >> x[i];
    for (int i = 0; i < 20; i++)
    {
        f = true;
        for (int j = 0; j < 20; j++)
            if (x[i] == x[j] && i != j)
                f = false;
        if (f)
            k++;
    }
    cout << k << endl;
    system("PAUSE > NULL");
    return EXIT_SUCCESS;
}
1
ForEveR
В астрале
Эксперт С++
7978 / 4737 / 321
Регистрация: 24.06.2010
Сообщений: 10,543
Завершенные тесты: 3
06.03.2012, 13:16 #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
#include <map>
#include <vector>
#include <random>
#include <ctime>
#include <algorithm>
#include <iterator>
 
int main()
{
   const size_t begin = 0, end = 20, size = 20;
   std::mt19937 gen(time(0));
   std::uniform_int_distribution<> distr(begin, end);
   std::vector<int> vec(size);
   std::generate(vec.begin(), vec.end(), [&gen, &distr]() { return distr(gen); });
   std::copy(vec.begin(), vec.end(), std::ostream_iterator<int>(std::cout, " "));
   std::cout << std::endl;
   std::map<int, int> mapper;
   std::for_each(vec.begin(), vec.end(), [&mapper](const int val) { ++mapper[val]; });
   std::cout << std::count_if(mapper.begin(), mapper.end(), [](const std::pair<int, int>& pair) 
         { return pair.second == 1; }) << std::endl;
}
http://liveworkspace.org/code/45cb7e...5d11ba6afc5cda

Так же можно было отсортировать, сделать unique_copy и взять размер получившегося контейнера.
1
Dekio
Фрилансер
Эксперт С++
5837 / 1218 / 214
Регистрация: 23.11.2010
Сообщений: 3,378
Записей в блоге: 1
06.03.2012, 14:01 #4
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <algorithm>
#include <iterator>
#include <vector>
#include <cstdlib>
#include <ctime>
#include <set>
 
int main()
{
    srand(time(0));
    const size_t size = 15;
    std::vector <int> vec(size);
    std::generate(vec.begin(), vec.end(), [] () -> int { return rand()%20; });
    std::copy(vec.begin(), vec.end(), std::ostream_iterator <int> (std::cout, " "));
    std::set <int> Set(vec.begin(), vec.end());
    std::cout<<std::endl<<Set.size()<<std::endl;
    return 0;
}
http://liveworkspace.org/code/ad86c8...29140bece0b9d6
2
ForEveR
06.03.2012, 14:08
  #5

Не по теме:

Dekio, Омг. А про сет то я и забыл...

1
denys_l
52 / 52 / 4
Регистрация: 26.09.2011
Сообщений: 186
06.03.2012, 18:28 #6
не то дал ) сорри
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.03.2012, 18:28
Привет! Вот еще темы с ответами:

Найти количество различных элементов в массиве. - C++
Найти количество различных элементов в массиве.

Найти количество различных элементов в массиве - C++
Ребят помогите решить задачу на с++. Условие: Дан целочисленный массив размера N. Необходимо найти количество разных елементов в данном...

Посчитать количество различных элементов в массиве - C++
Дан линейный массив целых чисел ввести с клавиатуры не менее 10 элементов и посчитать сколько в нем различных чисел . помогите решить ...

Количество различных элементов в монотонном массиве - C++
Пожалуйста помогите решить сначала задано N - количество элементов в массиве (N не превосходит 100). Далее через пробел записаны N...


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

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

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