0 / 0 / 0
Регистрация: 17.10.2016
Сообщений: 19
1

Вывести не повторяющиеся элементы массива

20.02.2017, 01:51. Показов 3438. Ответов 7
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Как сравнить введенные элементы массива и вывести те, что не повторяются?


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <cstring>
 
int main()
{
    using namespace std;
    const char N=10;
    char word[N];
    int i = 0;
    int count = 0;
    cout << "Enter any words (enter done to quit): ";
    do
    {
        cin >> word;
        ++count;
    } while (strcmp(word, "done") != 0);
    
    cout << "You entered " << count << " words except done.";
 
    cin.get();
    cin.get();
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.02.2017, 01:51
Ответы с готовыми решениями:

Заменить повторяющиеся элементы рандомного массива на нули и вывести их в конец массива
Заменить повторяющиеся элементы рандомного массива на нули и вывести полученные нули в конец...

Вывести упорядочены по убыванию повторяющиеся элементы произвольного одномерного массива
Вывести упорядочены по убыванию повторяющиеся элементы произвольного одномерного массива целых...

Повторяющиеся элементы массива
Есть произвольный массив, в котором нужно отсортировать повторяющиеся элементы по уменьшению и...

Вывести элементы матрицы, повторяющиеся 1 и более раз
Дан двумерный массив, нужно вывести элементы, повторяющиеся 1 и более раз. Вот мой код: #include...

7
63 / 35 / 25
Регистрация: 17.07.2014
Сообщений: 457
20.02.2017, 02:23 2
Используем стандартную библиотеку и задействуем множество (set). При вставке элемента в множество он не будет туда вставлен, если уже там есть идентичный ему элемент.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include <set>
#include <string>
 
using namespace std;
 
int main()
{
    string word;
    set<string> s;
    while (word != "done")
    {
        cin >> word;
        s.insert(word);
    }
 
    for (auto element : s)
    {
        cout << element << " ";
    }
}
1
0 / 0 / 0
Регистрация: 17.10.2016
Сообщений: 19
20.02.2017, 02:38  [ТС] 3
А как правильнее это встроить в мой код? просто пока по синтаксису беда, можешь запостить полностью код? (твой + мой)
0
18 / 17 / 22
Регистрация: 03.05.2016
Сообщений: 105
20.02.2017, 03:54 4
Если надо самому, то отсортируй массив, а потом сравнивай его с рядом стоящим, а вот как сам подумай. И учитывай вариант если есть 3 и более одинаковых числа
0
0 / 0 / 0
Регистрация: 17.10.2016
Сообщений: 19
20.02.2017, 16:48  [ТС] 5
Есть еще варианты реализации?
0
Форумчанин
Эксперт CЭксперт С++
8215 / 5045 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
20.02.2017, 16:56 6
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
#include <string>
#include <sstream>
#include <map>
 
int main()
{
    std::string str;
    std::getline(std::cin, str);
 
    std::istringstream ist(str);
    std::map<std::string, int> m;
    for (std::string word; ist >> word; ++m[word]);
 
    for (const auto &p : m)
        if (p.second == 1)
            std::cout << p.first << std::endl;
}
Если нужно вывести все слова без повторений (то есть выводить из дублей только одно слово, а не не выводить вообще):
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
#include <iterator>
#include <set>
#include <sstream>
#include <string>
 
int main()
{
    std::string str;
    std::getline(std::cin, str);
 
    std::istringstream ist(str);
    for (const auto &s : std::set<std::string>{ std::istream_iterator<std::string>(ist), std::istream_iterator<std::string>() })
        std::cout << s << std::endl;
}
1
0 / 0 / 0
Регистрация: 17.10.2016
Сообщений: 19
20.02.2017, 17:07  [ТС] 7
А как целиком код должен выглядить? т.е. куда это надо встроить в мой код?
0
Форумчанин
Эксперт CЭксперт С++
8215 / 5045 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
20.02.2017, 17:20 8
Цитата Сообщение от aqostic Посмотреть сообщение
А как целиком код должен выглядить? т.е. куда это надо встроить в мой код?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <string>
#include <map>
 
int main()
{
    std::map<std::string, int> m;
    for (std::string word; std::cin >> word && word != "done"; ++m[word]);
 
    for (const auto &p : m)
        if (p.second == 1)
            std::cout << p.first << std::endl;
}
Добавлено через 1 минуту
Либо так (дубли выводятся, но один раз):
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <iostream>
#include <set>
#include <string>
 
int main()
{
    std::set<std::string> s;
    for (std::string word; std::cin >> word && word != "done"; s.insert(word));
 
    for (const auto &w : s)
        std::cout << w << std::endl;
}
0
20.02.2017, 17:20
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.02.2017, 17:20
Помогаю со студенческими работами здесь

Найти повторяющиеся элементы массива
Необходимо написать программу которая будет находить все повторяющиеся елементы в массиве....

Удалить из массива повторяющиеся элементы
Удалить из массива повторяющиеся элементы.жду вашим решений

Удалить все повторяющиеся элементы массива
Удалить все повторяющиеся элементы массива. Как сделать, чтобы элементы удалялись, а не...

Исключить из массива все повторяющиеся элементы
Дан массив. Допустим я ввожу элементы 1,2,3,2,4 И нужно создать новый массив чтобы одинаковых...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru