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

Вывод слов из строки - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вывести на экран координаты точки, наиболее удаленной от начала координат http://www.cyberforum.ru/cpp-beginners/thread651228.html
2. С помощью ГСЧ задать матрицу А(5,2), содержащую координаты точек на плоскости. Вывести ее на экран в прямоугольном виде. Вывести на экран координаты точки, наиболее удаленной от начала координат....
C++ поиск длины пути Всем доброго утра Ребята подскажите пожалуйста алгоритм дана матрица расстояний n*n, в ячейках расположены расстояний между i и j объектами нужно сформировать массив который будет хранить сумму... http://www.cyberforum.ru/cpp-beginners/thread651226.html
Размеры переменных C++
Здравствуйте! Простите за такой вопрос, но я до сих не понял что такое размер переменной. Объясните пожалуйста что такое размер(ширина) переменной ? Например: размер int-а (в зависимости от...
Найти координаты четвертой вершины квадрата C++
1. На плоскости заданы координаты трех вершин квадрата АВСД - вершин А, В и С. Найти координаты четвертой вершины
C++ Цикличные алгоритмы http://www.cyberforum.ru/cpp-beginners/thread651206.html
Помогите решить!!! )))) я на вас надеюсь. от этого зависит моя судьба))) Вычислить сумму ряда с погрешностью ε=0,0001 для заданного x. Сравните результаты с точным значением функции, для которого...
C++ Динамический массив структур Нужно создать базу данных библиотеки состоящую из структур: книга, автор, количество читателей взявших эту книгу. Реализовать функции: ввода, вывода, добавления, удаления из динамического массива... подробнее

Показать сообщение отдельно
BrooDRay
0 / 0 / 0
Регистрация: 12.08.2011
Сообщений: 8

Вывод слов из строки - C++

13.09.2012, 08:44. Просмотров 1584. Ответов 7
Метки (Все метки)

Суть задачи:
Дан текст, состоящий из N (2<=N<=10) строк с максимальной длиной 80 символов.
Необходимо вывести в обратном алфавитном порядке те слова,
длина которых не превышает K символов.
Считать, что текст написан синтаксически грамотно,
в качестве знаков препинания использу-ются точка и запятая,
слова состоят только из букв, перенос слов по слогам отсутствует.
Для выделения слов из строки создать пользовательскую функцию.

Где-то допустил ошибку и программа работает не совсем корректно. Укажите на ошибки хотя бы.

Вот код:
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include "stdafx.h"
#include <iostream>
#include <string>
int NewWords(char* string);
bool GetWord(char* string, char* word, int& wordSet);
int _tmain(int argc, _TCHAR* argv[])
{
    char String[81] = {0};
    int SizeString = 80;
    int n,k;
    std::cout << "How a lot of symbols in the word?" << std::endl;
    std::cin >> k;
    std::cout << "How a lot of strings you will use?" << std::endl;
    do
    std::cin >> n;
    while(n<2 || n >= 10);
    char **Strings = new char* [n];
    std::cout << "Please enter strings." << std::endl;
    for(int i = 0; i < n; i++)
    {
        Strings[i] = new char [81];
        std::cin.get();
        std::cin.getline(String,SizeString);
        //std::cin.get();
        strcpy(Strings[i],String);
    }
 
    int nsws = 0;
    for(int i = 0; i < n; i ++)
        nsws+=NewWords(Strings[i]);
    char **NewStrings = new char* [nsws];
    for(int i = 0; i < nsws; i++)
        NewStrings[i] = new char [80];
 
    int z;
    for(int s = 0; s < n; s++)
    {
        int wordSet = 0;
        int i = 0;
        while (GetWord(Strings[s],String,wordSet))
        {
            if(k>(int)strlen(String))
            {
                strcpy(NewStrings[i],String);
                z = i++;
            }
        }
    }
    //Сортируем в обратном алфавитном порядке
    for(int i = 0; i < z - 1; i++)
        {
        for(int j = i + 1; j < z; j++)
        if( strcmp(NewStrings[i] , NewStrings[j]) < 0 )
            {
        char* tmp = NewStrings[i];
        NewStrings[i] = NewStrings[j];
        NewStrings[j] = tmp;
            }
        }
 
    for(int i = 0; i < n; i++)
        puts(NewStrings[i]);
    system("pause");
    return 0;
}
 
int NewWords(char* string)
{
    int rw = 0;//переменная за подсчет количества слов в строке
    int dop = 0,dop2 = 0;
    for(int i = 0; string[i]!='\0'; i++)
    {
        if(string[i] == ' '|| string[i] == ',' || string[i] == '.' || string[i] == '\t')
        {
            dop++;
            if(dop-1>dop2) rw--;
            rw++;
        }
        else
        {
            dop = 0;    
        }
    }
    return rw;
}
 
bool GetWord(char* string, char* word, int& wordSet)
{
    if(!string[wordSet])
        return false;
    char *p1, *p2;
    p1 = p2 = string + wordSet;
    for(int i = 0; i < (int)strlen(p1) && !isalnum(p1[0]); i++)
        p1++;
    if(!isalnum(p1[0]))
        return false;
    p2 = p1;
    while(isalnum(p2[0]))
        p2++;
    int lenght = int (p2-p1);
    strncpy(word,p1,lenght);
    word[lenght] = '\0';
    for(int i = int(p2-string); i < (int)strlen(string) && !isalnum(p2[0]);i++)
        p2++;
    wordSet = int(p2-string);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru