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

Сортировка слов по их длине - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Sound(); http://www.cyberforum.ru/cpp-beginners/thread1125094.html
Подскажите что подключать и как использовать, Юзаю DevC++.
C++ Создать класс Money Задача: Создать класс Money для работы с денежными суммами.Число должно быть представлено двумя полями: типом long для рублей и типом unsigned char - для копеек. дробная часть(копейки) при выводе на экран должна быть отделена от целой части запятойю реализовать сложение,вычитание, деление сумм, деление суммы на дробное число, умножение на дробное число и операцию сравнения. В чем требуется... http://www.cyberforum.ru/cpp-beginners/thread1125073.html
C++ Заданное множество точек на плоскости. Найти выпуклую оболочку этого множества
Заданное множество точек на плоскости. Найти выпуклую оболочку этого множества, то есть выпуклый многоугольник с вершинами в некоторых точках этого множества, охватывающий все точки. Если честно даже не представляю как ее делать, помогите пожалуйста.
C++ Нужно считать данные из файла и заменить определенный текст на заданный
Есть файл с таким содержимым: (в нем записаны вещ. числа) Пример: 1.000 1.111 2.222 3.333 4.444 5.555 6.555 4.333 3.333 4.444 6.666 7.777 Нужно заметить, что 1.000 1.111 - это в рамках моей программы ОДНО число (и также это один столбец, а вовсе не два!). Часть 1.000 я записываю в экземпляр структуры One (см.ниже), часть 1.111 в Two. (!) Кроме того, таких чисел может быть уйма, однако...
C++ С чего начинать изучение C++. Книги http://www.cyberforum.ru/cpp-beginners/thread1125051.html
Прошу совета опытных людей. С чего начать учить С++ ? С какой книги будет легче стартануть ?
C++ Длинная арифметика Вот изучаю с++ попробывал написать длинную арифметику, но не сложение не деление которое мне необходимо не работает помогите найти ошибку в моем коде пожалуйста ;D зарание спасибо #include <iostream> using namespace std; void StrToMasiv(string S, int T) { int i, n; n=S.size(); подробнее

Показать сообщение отдельно
MicM
821 / 488 / 90
Регистрация: 29.12.2009
Сообщений: 1,097
Завершенные тесты: 1
20.03.2014, 20:29     Сортировка слов по их длине
И я:
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;
}
 
Текущее время: 04:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru