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

Дописать код сортировки - C++

Восстановить пароль Регистрация
 
Ysida
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 9
25.05.2014, 14:26     Дописать код сортировки #1
Что дописать,если строчек у меня n штук,нужно удалять лишние символы разделители, т.е. идет у меня подряд .,; и так после каждого слова есть лишние символы-разделители,оставался лишь первый разделитель, и не нуждающиеся в сортировке строки тоже нужно удалить.
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
67
68
69
70
71
72
73
74
75
76
77
78
79
#include <iostream>
#include <cctype>
#include <cstring>
 
int NumbersOfWords (const char *str)
{
    int k = 0;
    int length = std::strlen(str);
    bool flag = false;
    for (int i=0; i<=length; i++)
    {
        if ((!std::isalpha(str[i]) || str[i]=='\0') && flag)
        {
            ++k;
            flag = false;
        }
        else if (std::isalpha(str[i]) && !flag)
            flag = true;
    }
    return k;
}
 
const int maxLength = 128;
 
struct Word
{
    int length;
    char str[maxLength];
};
 
int main()
{
    char str[maxLength]="", temp[maxLength];
    std::cin.get(str,maxLength);
    Word *mas = new Word[NumbersOfWords(str)];
    int length = std::strlen(str), tempLength;
    int i = 0, k = 0;
    while (i<length)
    {
        if (std::isalpha(str[i]))
        {
            tempLength = 0;
            std::strcpy (temp,"");
            while (i<length && std::isalpha(str[i]))
            {
                temp[tempLength] = str[i];
                ++tempLength;
                ++i;
            }
            temp[tempLength] = '\0';
            mas[k].length = tempLength;
            std::strcpy (mas[k].str, temp);
            ++k;
        }
        else ++i;
    }
    Word tmp;
    bool flag;
    do
    {
        flag = true;
        for (int i=0; i<k-1; i++)
        {
            if (mas[i].length > mas[i+1].length)
            {
                tmp = mas[i];
                mas[i] = mas[i+1];
                mas[i+1] = tmp;
                flag = false;
            }
        }
    }
    while (!flag);
    for (int i=0; i<k; i++)
        std::cout <<mas[i].str <<' ';
    std::cout <<'\n';
    delete [] mas;
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.05.2014, 14:26     Дописать код сортировки
Посмотрите здесь:

C++ Дописать код в файл!
C++ Дописать код
C++ Дописать код программы
C++ Нужно дописать код на С++
C++ Дописать код
Дописать код по алгоритму C++
C++ Дописать код
C++ Дописать функцию сортировки по алфавиту в базе данных

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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