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

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

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

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

21.03.2013, 23:26. Просмотров 706. Ответов 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;
}
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.03.2013, 23:26
Здравствуйте! Я подобрал для вас темы с ответами на вопрос В одномерном массиве найти количество различных элементов (C++):

Найти количество различных элементов в одномерном массиве - C++
2 л.р. Найти количество различных элементов в одномерном массиве Добавлено через 21 минуту Считать массив динамическим

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

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

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

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

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

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Croessmah
Эксперт CЭксперт С++
13221 / 7493 / 845
Регистрация: 27.09.2012
Сообщений: 18,412
Записей в блоге: 3
Завершенные тесты: 1
22.03.2013, 02:33 #2
C++
1
if(i==a[j]) sob[i]=++;
Это что?
0
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, и в конечном итоге получим количество различных чисел в нашем массиве. Надеюсь ,моя идея ясна.
0
alsav22
5419 / 4815 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
23.03.2013, 02:58 #4
Идея ясна, только это непонятно:
C++
1
sob[i]=++;
Вы тут, что хотите сделаеть?
0
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;
}
Вот, пользуйся.
0
Кудаив
329 / 406 / 24
Регистрация: 27.05.2012
Сообщений: 1,168
Завершенные тесты: 2
23.03.2013, 09:01 #6
намешан С и С++...
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.03.2013, 09:01
Привет! Вот еще темы с ответами:

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

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

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

Найти количество одинаковых элементов подряд в одномерном массиве - C++
Здравствуйте!!!Помогите, пожалуйста, написать программу:Подсчитать количество одинаковых элементов одномерного массива, которые расположены...


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

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

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