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

Количество различных элементов в монотонном массиве - C++

Восстановить пароль Регистрация
 
rewq
0 / 0 / 0
Регистрация: 02.11.2012
Сообщений: 5
02.11.2012, 10:38     Количество различных элементов в монотонном массиве #1
Пожалуйста помогите решить

сначала задано N - количество элементов в массиве (N не превосходит 100). Далее через пробел записаны N целых чисел - элементы массива отсортированы по неубыванию (каждый элемент массива не меньше предыдущего элемента, например 1,2,2,3,3,3).
Необходимо вывести количество различных чисел в этом массиве.
Пример.
Входящие данные|Результат работы
6 4
1 2 2 5 7 7
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Marko
9 / 9 / 0
Регистрация: 05.07.2012
Сообщений: 38
02.11.2012, 10:54     Количество различных элементов в монотонном массиве #2
Пройдись по массиву, запихай элементы в set, в итоге с set'е будут только уникальные элементы.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
02.11.2012, 11:08     Количество различных элементов в монотонном массиве #3
C++
1
2
3
4
5
6
7
8
9
10
#include <vector>
#include <set>
#include <iostream>
 
int main()
{
   std::vector<int> v = {1,1,2,3,3,3,4,6,7,7};
   std::set<int> s(v.begin(), v.end());
   std::cout << s.size() << std::endl;
}
http://liveworkspace.org/code/390f1c...8255198362802a
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
02.11.2012, 11:14     Количество различных элементов в монотонном массиве #4
C
1
2
3
4
5
6
7
8
9
10
11
#include<stdio.h>
 
int main()
{
   int i, count, n, a[] = {1,1,2,3,3,3,4,6,7,7};
   n = sizeof(a) / sizeof(*a);
   for(i = count = 1; i < n; i++)
      count += (a[i-1] != a[i]);
   printf("count = %d\n", count);   
   return 0;    
}
c68c15
 Аватар для c68c15
4 / 4 / 1
Регистрация: 10.01.2010
Сообщений: 66
18.11.2012, 15:46     Количество различных элементов в монотонном массиве #5
C++
1
2
3
4
5
6
7
8
9
10
11
12
    for (i=0; i<n-1; i++)
        for (j=0; j<n-1; j++)
            if (a[j]>a[j+1])
            {
                t=a[j];
                a[j]=a[j+1];
                a[j+1]=t;
            }
 
    for (i=0; i<n; i++)
        if (a[i]!=a[i+1])
             r++;
Amandosov
Знаток
156 / 156 / 65
Регистрация: 18.11.2012
Сообщений: 411
Записей в блоге: 2
18.11.2012, 16:22     Количество различных элементов в монотонном массиве #6
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <conio.h>
#include <iostream>
using namespace std;
int main(){
        int n,k=1;
        cin>>n;
        int x[100];
        for(int i=0;i<n;i++){
            cin>>x[i];
        }
        for(int i=1;i<n;i++){
            if(x[i]>x[i-1]) k++;
        }
 
            cout<<n<<' '<<k;
 
        getch();
return 0;
}
Yandex
Объявления
18.11.2012, 16:22     Количество различных элементов в монотонном массиве
Ответ Создать тему
Опции темы

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