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

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

Восстановить пароль Регистрация
 
KattyAlex
 Аватар для KattyAlex
0 / 0 / 0
Регистрация: 02.01.2013
Сообщений: 26
21.03.2013, 23:26     В одномерном массиве найти количество различных элементов #1
Условие: в одномерном массиве найти количество различных элементов.
компилятор ругается
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++
C++ Найти количество различных элементов в массиве
C++ Найти в одномерном массиве, состоящем из N целых чисел, количество простых элементов
C++ В одномерном массиве случайных чисел найти количество нулевых элементов
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11835 / 6814 / 769
Регистрация: 27.09.2012
Сообщений: 16,889
Записей в блоге: 2
Завершенные тесты: 1
22.03.2013, 02:33     В одномерном массиве найти количество различных элементов #2
C++
1
if(i==a[j]) sob[i]=++;
Это что?
KattyAlex
 Аватар для 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
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
23.03.2013, 02:58     В одномерном массиве найти количество различных элементов #4
Идея ясна, только это непонятно:
C++
1
sob[i]=++;
Вы тут, что хотите сделаеть?
eocron
Кактус
 Аватар для 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;
}
Вот, пользуйся.
Кудаив
328 / 405 / 24
Регистрация: 27.05.2012
Сообщений: 1,162
Завершенные тесты: 2
23.03.2013, 09:01     В одномерном массиве найти количество различных элементов #6
намешан С и С++...
Yandex
Объявления
23.03.2013, 09:01     В одномерном массиве найти количество различных элементов
Ответ Создать тему
Опции темы

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