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

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

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

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

21.03.2013, 23:26. Просмотров 695. Ответов 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
31
32
33
34
35
36
37
#include<iostream>
#include<stdlib.h>
#include <time.h>
 
int main(){
 
    srand(time(0));
 
    const int n=10;
    int* a = new int[n];
 
    for( int i=0; i<10; i++){
        a[i]= rand()%10;
    }
 
    int number=0;
    int* sob=new int[n];
    const int m=9;
 
 
    for(int i=0, sob[n];i<m;i++){
        sob[i]=0;
       
        for(int j=0;j<n;j++)
    {
        if(i==a[j]) sob[i]=++;
        else   i++;}
 
    int kol=0;      
    for(int i=0; i<m; i++){
        if(sob[i]!=0) kol++;
    }
}
    std::cout<<"kolichestvo razlichnyh elementov ="<<kol<<std::endl;
    system("pause");
    return 0;
}
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.03.2013, 23:26     В одномерном массиве найти количество различных элементов
Посмотрите здесь:

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

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

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

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

Найти количество одинаковых элементов в одномерном массиве - C++
Здравствуйте, как определить количество одинаковых элементов в строке, если предположем массив из 5 элементов? вот мне нужно чтобы в строке...

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

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт CЭксперт С++
13051 / 7314 / 814
Регистрация: 27.09.2012
Сообщений: 18,051
Записей в блоге: 3
Завершенные тесты: 1
22.03.2013, 02:33     В одномерном массиве найти количество различных элементов #2
C++
1
if(i==a[j]) sob[i]=++;
Это что?
KattyAlex
0 / 0 / 0
Регистрация: 02.01.2013
Сообщений: 26
23.03.2013, 00:44  [ТС]     В одномерном массиве найти количество различных элементов #3
Мы берём в цикле по очереди число i в диапазоне от 0 до 9… и по очереди числа из массива, и проверяем, если число сравнимо с числом из массива, то тогда мы накапливаем значение в sob.
Иначе говоря, например, возьмём в цикле число i равное 1 и сравним с ячейкой a[1], если в ячейке единица, то тогда мы заносим это значение в sob1. Таким образом мы соберём в sob1, sob2, …sob9 все наши числа, которые присутствуют в массиве, а далее мы просто проверим: равняется ли наш sob[i] нулю, если да, то мы этот sob[i] отбросим, если нет – занесём в kol, и в конечном итоге получим количество различных чисел в нашем массиве. Надеюсь ,моя идея ясна.
alsav22
5416 / 4812 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
23.03.2013, 02:58     В одномерном массиве найти количество различных элементов #4
Идея ясна, только это непонятно:
C++
1
sob[i]=++;
Вы тут, что хотите сделаеть?
eocron
Кактус
66 / 66 / 6
Регистрация: 23.05.2012
Сообщений: 343
23.03.2013, 08:57     В одномерном массиве найти количество различных элементов #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>
 
using namespace std;
 
int main()
{
    int n;
    cin>>n;
    int *a=new int[n];
    int sob[10]; //массив под каждую чиселку 0-9
    int k=0; 
    memset(sob,0,sizeof(int)*10);
    srand(time(0));  
    for( int i=0; i<n; i++)
    {
        a[i]= rand()%10;
    }
 
    for(int i=0;i<n;i++)
    {
            sob[a[i]]++;//не зачем сравнивать, a[i] - рандомное число от 0 до 9,  sob[0] - количество нулей, sob[2] - количество двоек и тд.
    }
    
    for(int i=0;i<10;i++)
    {
            if(sob[i]>0){k++;}
    }
    cout<<"Num of dif: "<<k<<endl;
    cin>>k;
}
Вот, пользуйся.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.03.2013, 09:01     В одномерном массиве найти количество различных элементов
Еще ссылки по теме:

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

В одномерном массиве размерностью N найти количество отрицательных элементов - C++
Дано одномірний масив розмірністю N, знайти кількість від’ємних елементів масиву Язык форума - Русский. Перевожу В одномерном массиве...

Массив: Найти количество различных элементов в данном массиве - C++
Дано целочисленный массив размера N. Найти количество различных элементов в данном массиве.

В одномерном массиве случайных чисел найти количество нулевых элементов - C++
В одномерном массиве случайных чисел найти количество нулевых элементов

В заданном одномерном массиве найти количество элементов, меньших указанного числа - C++
В одномерном массиве, состоящем из п вещественных элементов, вычислить: • количество элементов массива, меньших С; • сумму целых...

Функция поиска в одномерном массиве: найти количество положительных и отрицательных элементов - C++
как в С++ пишется функция поиск? что то типо этого: poisk(A, n); void poisk(int** a, int n)


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

Или воспользуйтесь поиском по форуму:
Кудаив
329 / 406 / 24
Регистрация: 27.05.2012
Сообщений: 1,165
Завершенные тесты: 2
23.03.2013, 09:01     В одномерном массиве найти количество различных элементов #6
намешан С и С++...
Yandex
Объявления
23.03.2013, 09:01     В одномерном массиве найти количество различных элементов
Ответ Создать тему
Опции темы

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