Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
KattyAlex
0 / 0 / 0
Регистрация: 02.01.2013
Сообщений: 26
1

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

21.03.2013, 23:26. Просмотров 1181. Ответов 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)
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.03.2013, 23:26
Ответы с готовыми решениями:

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

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

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

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

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

5
Croessmah
++Ͻ
16155 / 9246 / 1774
Регистрация: 27.09.2012
Сообщений: 22,794
Записей в блоге: 2
Завершенные тесты: 2
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
5465 / 4860 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
23.03.2013, 02:58 4
Идея ясна, только это непонятно:
C++
1
sob[i]=++;
Вы тут, что хотите сделаеть?
0
eocron
Кактус
67 / 67 / 19
Регистрация: 23.05.2012
Сообщений: 342
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
Кудаив
414 / 413 / 72
Регистрация: 27.05.2012
Сообщений: 1,168
Завершенные тесты: 2
23.03.2013, 09:01 6
намешан С и С++...
0
23.03.2013, 09:01
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.03.2013, 09:01

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

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

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

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

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