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

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

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

Удаление повторяющихся чисел из массива - C++

08.11.2010, 20:03. Просмотров 710. Ответов 4
Метки нет (Все метки)

допустим есть массив a[]={1,1,1,1,54,84,63,554,54,85,32,84,1,2,6,85}
нужно в массиве оставить все числа по одному экземпляру: a[]={1,54,84,63,554,85,32,2,6}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.11.2010, 20:03     Удаление повторяющихся чисел из массива
Посмотрите здесь:

Удаление из массива повторяющихся элементов C++
Удаление повторяющихся точек C++
Удаление повторяющихся символов C++
C++ Удаление повторяющихся символов
C++ Вывод повторяющихся чисел массива и количество повторений
C++ Перебор массива и поиск повторяющихся чисел
C++ Удаление повторяющихся чисел. Ошибка в коде
C++ Удаление повторяющихся символов массива
C++ Сохранение строки в массив и удаление повторяющихся элементов массива
Подсчет повторяющихся чисел одномерного массива C++
C++ Удаление повторяющихся символов
Удаление повторяющихся чисел C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Lerny
56 / 56 / 3
Регистрация: 14.03.2010
Сообщений: 151
08.11.2010, 20:31     Удаление повторяющихся чисел из массива #2
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
#include <iostream>
#include <conio>
#include <vector>
using namespace std;
 
void main()
{
        vector <int> m1;
        int a[]={1,1,1,1,54,84,63,554,54,85,32,84,1,54,6,85};
        for (int i=0;i<16;i++)
        {
             bool tr=false ;
                for (int j=0;j<i;j++)
                   if (a[i]==a[j]){
                   tr=true;
                   break;}
             if (tr==false)
             m1.push_back(a[i]);
        }
 
        for (int i=0;i<m1.size();i++)
        cout << m1[i]<<" ";
        getch();
}
PointsEqual
ниначмуроФ
834 / 518 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
09.11.2010, 01:52     Удаление повторяющихся чисел из массива #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <vector>
#include <algorithm>
 
int main()
{
    const int size = 16;
    int m[size] = {1,1,1,1,54,84,63,554,54,85,32,84,1,2,6,85};
    std::vector<int> arr(m, m+size);
 
    sort(arr.begin(),arr.end());
    std::vector<int>::iterator it = unique(arr.begin(),arr.end());
    arr.resize( it - arr.begin() );
 
    for(std::vector<int>::iterator i = arr.begin(); i != arr.end(); ++i)
       std::cout << *i << " ";
 
    return 0;
}
TheMachinist
242 / 174 / 15
Регистрация: 14.06.2010
Сообщений: 422
09.11.2010, 12:07     Удаление повторяющихся чисел из массива #4
Здесь лучше set использовать(или как он там по-русски обзывается)
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
#include<set>
using namespace std;
 
int main()
{ 
int a[]={1,1,1,1,54,84,63,554,54,85,32,84,1,2,6,85};
set<int>myset(a,a+16);
set<int>::iterator it;
int N = myset.size();
int * a1 = new int[N]; int i = 0;
for(it = myset.begin();it != myset.end();it++,i++){
a1[i] = *it;
cout << a1[i] << " ";}
    
system("pause");
return 0;
    }
fasked
Эксперт С++
4933 / 2513 / 180
Регистрация: 07.10.2009
Сообщений: 4,311
Записей в блоге: 1
09.11.2010, 12:15     Удаление повторяющихся чисел из массива #5
NikolaWhite, set разве их не отсортирует в придачу? unique то использовать получше будет, как PointsEqual предложил. как раз по назначению.
Yandex
Объявления
09.11.2010, 12:15     Удаление повторяющихся чисел из массива
Ответ Создать тему
Опции темы

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