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

Удалить повторяющиеся слова - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с файлами. Из имеющего файла по сортировать в отдельные файлы http://www.cyberforum.ru/cpp-beginners/thread802476.html
Доброго времени суток Ув., сайберчани. Прошу помочь, а лучше наставить на путь как решить эту проблему. Нужно из имеющего файла в котором хранятся положительные и отрицательные числа , по сортировать в отдельные файлы, один файл с отрицательными, другой с положительными. Я вот не много сделал, но берет только по 1 значению и в цикле повторяет его . #include <fstream> #include <iostream> ...
C++ Создание программы наподобие игры "кто хочет стать миллионером" А возможно ли создать программу которая например выдает вопрос из 100 рандомно и 4 варианта ответа с считывает их и считает кол-во ответов ну на подобе игры кто хочет стать миллионером http://www.cyberforum.ru/cpp-beginners/thread802443.html
C++ посмотрите код, в чем не правильно! (определить наименьшее неотрицательное целое k такое, что b < 2k)
Для каждого числа b из 20 чисел, вводимых с клавиатуры определить наименьшее неотрицательное целое k такое, что b < 2k. код: #include <iostream> #include <conio.h> using namespace std; int main() { int k,b;
C++ Не могу сделать считывание матрицы 4 на 4 из файла
#include <iostream> #include <iomanip> #include <conio.h> using namespace std; int main() { int n; cout<<"Vvedite razmernost matricy:"<<endl; cin >> n; float** arr = new float* ;
C++ Разработка и отладка алгоритмов и программ с использованием указателей http://www.cyberforum.ru/cpp-beginners/thread802419.html
Задача 1. В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1) максимальный по модулю элемент массива; 2) сумму элементов массива, расположенных между первым и вторым положительными элемен-тами. Преобразовать массив таким образом, чтобы элементы, равные нулю, располагались после всех остальных, распечатать их адреса. Задача 2. В одномерном массиве, состоящем из n...
C++ Опытные программисты , нужно сделать считывание с файла матрицы 4*4 #include <iostream> #include <iomanip> #include <conio.h> using namespace std; int main() { int n; cout<<"Vvedite razmernost matricy:"<<endl; cin >> n; float** arr = new float* ; подробнее

Показать сообщение отдельно
kamre
126 / 130 / 4
Регистрация: 25.12.2011
Сообщений: 443
07.03.2013, 03:49     Удалить повторяющиеся слова
Цитата Сообщение от Katushechka Посмотреть сообщение
чтоб все было сделано без подключений string и string.h
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#include <iostream>
#include <vector>
#include <set>
 
using namespace std;
 
typedef vector<char> str_t;
typedef set<str_t> set_t;
 
ostream& operator<<(ostream& out, const str_t& s)
{
    return out << &s[0];
}
 
void print_set(const char* name, const set_t& s)
{
    if (!s.empty()) {
        cout << name << ": ";
        set_t::const_iterator iter;
        for (iter = s.begin(); iter != s.end(); ++iter) {
            cout << *iter << " ";
        }
        cout << endl;
    }
}
 
void sort_words(const char* s, set_t& uniq, set_t& dups)
{
    uniq.clear();
    dups.clear();
    str_t word;
    char c;
    do {
        c = *s++;
        if (c != ' ' && c != '\0') {
            word.push_back(c);
        } else if (word.size() > 0) {
            word.push_back('\0');
            if (dups.find(word) == dups.end()) {
                if (uniq.find(word) == uniq.end()) {
                    uniq.insert(word);
                } else {
                    uniq.erase(word);
                    dups.insert(word);
                }
            }
            word.clear();
        }
    } while (c);
}
 
int main(int argc, char **argv) {
    enum { sz = 101 };
    char buf[sz];
    const char* inp = buf;
    if (argc <= 1) {
        cin.getline(buf, sz);
    } else {
        inp = argv[1];
        cout << "input: " << inp << endl;
    }
    set_t uniq, dups;
    sort_words(inp, uniq, dups);
    print_set("unique", uniq);
    print_set("duplicates", dups);
}
 
Текущее время: 08:26. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru