Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 03.04.2019
Сообщений: 9
1

Преобразовать каждое предложение так, что символы в каждом слове шли в обратном порядке

04.04.2019, 20:22. Показов 831. Ответов 8

Author24 — интернет-сервис помощи студентам
Требуется преобразовать каждое предложение так, что символы в каждом слове шли в обратном порядке.
abc = cba
Есть Динамический массив строк, ввод с клавиатуры через пробел и точку
Каким образом перевернуть слова во введенной строке?
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <string.h>
 
#define SIZE 50
#define SEPARATORS " ,"
 
void print_text(char*** text, int size) {
    for (int i = 0; i < size; i++) {
        printf("%s\n", (*text)[i]);
    }
}
void delete_sent_with_comma(char*** text, int* size) {
    for (int i = 0; i < *size; i++){
        for (int q = 0; q < strlen((*text)[i]); q++){
            if((*text)[i][q] == ','){
                for(int s = i; s < *size - 1; s++){
                    (*text)[s] = (*text)[s + 1];
                }
                free((*text)[*size]);
                (*size)--;
            }
        }
    }
}
int unique_sent (char* sentence, char*** text, int n) {
    if (n == 0) {
        return 1;
    }
    for (int i = 0; i < n; i++) {
        if (!strcasecmp((*text)[i], sentence)) {
            return 0;
        }
        return 1;
    }
}
 
/*int reverse_sentence (char* sentence, char*** text, int n) {
    //char res[] = calloc(n, sizeof(char));
    int i = 0;
    int j;
    char* p;
    for (p = strtok(sentence, SEPARATORS); p; p = strtok(NULL, SEPARATORS)) {
        for (j = strlen(p) - 1; j >= 0; --j, ++i) {
            res[i] = p[j];
        }
        res[i] = ' ';
        ++i;
    }
    res[i] = '\0';
    printf("%s", res);
    return res;
}
*/
 
//int delete_sent_with_comma(char*** text, int* size) {
//    for (int i = 0; i < n; i++)
//}
 
void text_input(char*** text, int* size) {
    int len_sentence = SIZE;
    int len_text = SIZE;
 
    int i = 0;
    int n = 0;
 
    char *sentence = calloc(len_sentence + 1, sizeof(char));
    *text = calloc(len_text + 1, sizeof(char*));
    char c;
 
    while(1){
        c = getchar();
 
        while(((c == ' ') || (c == '\t')) && strlen(sentence) == 0) c = getchar();
 
        if (i + 1 == len_sentence) {
            len_sentence += SIZE;
            sentence = realloc(sentence, len_sentence * sizeof(char));
        }
 
        sentence[i++] = c;
 
        if(c == '\n') {
            *size = n;
            break;
        }
 
        if(c == '.') {
            if(n + 1 == len_text) {
                len_text += SIZE;
                (*text) = realloc((*text), len_text * sizeof(char*));
            }
 
            (*text)[n] = calloc(len_sentence + 1, sizeof(char));
            strcpy((*text)[n], sentence);
            n++;
 
            free(sentence);
            sentence = calloc(len_sentence + 1, sizeof(char));
            i = 0;
        }
    }
}
int main() {
    int size = 0;
    int option;
    char **text = NULL;
    puts("\n <<<Enter the text>>>");
 
    text_input(&text, &size);
 
    /*while(size == 0) {
        puts("Error, try again");
        text_input(&text, &size);
    }*/
 
    puts("Text entered. Enter the number of option to go.");
    puts("1: Print text, and number of repeats");
    puts("2: Reverse all words");
    puts("3: Delete sentence with comma");
    puts("4: Sentence sort");
    puts("0: Exit");
 
    //scanf("%d", &option);
 
    /*switch(option) {
        case 0:
            puts("End of program");
            exit(0);
        case 1:
            //
        case 2:
            reverse_sentence()
    }*/
    delete_sent_with_comma(&text, &size);
    print_text(&text, size);
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.04.2019, 20:22
Ответы с готовыми решениями:

В Каждом слове текста переписать все символы в обратном порядке
Здравствуйте, помогите, пожалуйста, решить задачу. Пытался разными способами, но никак не...

В Каждом слове текста переписать все символы в обратном порядке
Здравствуйте, помогите, пожалуйста, решить задачу. Пытался разными способами, но никак не...

Преобразовать строку так, чтобы сначала шли цифры, а затем все буквы исходной строки, но в обратном порядке
1)Дана строка,содержащая буквы и цифры.Преобразовать строку так,что бы сначала шли цифры,а затем...

Чтобы предложение перестроилось и слова в нём шли в обратном порядке
Последним действием надо сделать так, чтобы предложение перестроилось и слова в нём шли в обратном...

8
35 / 28 / 8
Регистрация: 01.03.2019
Сообщений: 135
04.04.2019, 20:50 2
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
void ReverseWords(char *str)
{
    size_t word_beg = 0;
    size_t word_len = 0;
 
    for (size_t i = 0;; i++)
    {
        if (str[i] == ' ' || str[i] == '\0') {
            if (word_len > 1) {
                for (size_t i = 0; i <= word_len / 2; i++)
                {
                    char tmp = str[word_beg + i];
                    str[word_beg + i] = str[word_beg + word_len - i];
                    str[word_beg + word_len - i] = tmp;
                }
            }
            word_beg = i + 1;
            word_len = 0;
            if (str[i] == '\0')
                return;
        }
        else
            word_len++;
    }
}
1
Диссидент
Эксперт C
 Аватар для Байт
27710 / 17328 / 3810
Регистрация: 24.12.2010
Сообщений: 38,979
04.04.2019, 20:55 3
CrystalBlaade, В простыне твоего кода разбираться не стал. Уж больно она длинна и широка. Но если нужно просто перевернуть строку, то это делается обычно так:
C
1
2
3
4
5
6
7
char s[] = "abcdefghi";
int n = strlen(s);
for(i=0; i<n/2; i++) {
 char t = s[i];
 s[i] = s[n-i-1];
 s[n-i-1] = t;
}
Добавлено через 2 минуты
Ну вот, уважаемыйALast помог тебе немного больше. Даже разбил за тебя строку на слова...
0
35 / 28 / 8
Регистрация: 01.03.2019
Сообщений: 135
04.04.2019, 20:58 4
Байт, только код работает неверно...
CrystalBlaade, мой код работает неверно
0
Диссидент
Эксперт C
 Аватар для Байт
27710 / 17328 / 3810
Регистрация: 24.12.2010
Сообщений: 38,979
04.04.2019, 21:03 5
Цитата Сообщение от ALast Посмотреть сообщение
код работает неверно...
Чей?
0
35 / 28 / 8
Регистрация: 01.03.2019
Сообщений: 135
04.04.2019, 21:23 6
Вроде пофиксил
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
void ReverseStr(char *str, size_t len)
{
    for (size_t i = 0; i < len / 2; i++)
    {
        char tmp = str[i];
        str[i] = str[len - i - 1];
        str[len - i - 1] = tmp;
    }
}
 
 
void ReverseWords(char *str)
{
    size_t word_beg = 0;
    size_t word_len = 0;
 
    for (size_t i = 0;; i++)
    {
        if (str[i] == ' ' || str[i] == '\0') {
            if (str[i] == '\0') {
                ReverseStr(str + word_beg, word_len - 1);
                return;
            }
            if (word_len > 1)
                ReverseStr(str + word_beg, word_len);
                word_beg = i + 1;
            word_len = 0;
        }
        else
            word_len++;
    }
}
Добавлено через 18 секунд
Цитата Сообщение от Байт Посмотреть сообщение
Чей?
мой конечно)

Добавлено через 18 минут
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
const char Dividers[] = " :,;!?.";
 
 
int IsAtStr(const char* str, char symbol)
{
    for (const char *ptr = str; *ptr != '\0'; ptr++)
        if (*ptr == symbol)
            return 1;
    return 0;
}
 
 
void ReverseStr(char *str, size_t len)
{
    for (size_t i = 0; i < len / 2; i++)
    {
        char tmp = str[i];
        str[i] = str[len - i - 1];
        str[len - i - 1] = tmp;
    }
}
 
 
void ReverseWords(char *str)
{
    size_t word_beg = 0;
    size_t word_len = 0;
 
    for (size_t i = 0;; i++)
    {
        if (IsAtStr(Dividers, str[i]) || str[i] == '\0') {
            if (str[i] == '\0') {
                if (word_len > 1)
                    ReverseStr(str + word_beg, word_len - 1);
                return;
            }
            if (word_len > 1)
                ReverseStr(str + word_beg, word_len);
            word_beg = i + 1;
            word_len = 0;
        }
        else
            word_len++;
    }
}
0
85 / 61 / 29
Регистрация: 15.05.2013
Сообщений: 188
05.04.2019, 10:45 7
void ReverseStr(char *str, size_t len)
Я хочу обратить внимание на использование size_t. Чревато последствиями если функция будет вызвана с отрицательным значением len. Если не устраивает стандартный int или long, тогда есть знаковый ssize_t.
1
35 / 28 / 8
Регистрация: 01.03.2019
Сообщений: 135
05.04.2019, 10:50 8
Цитата Сообщение от shadowmaan Посмотреть сообщение
отрицательным значением len
В 33 строке
Цитата Сообщение от ALast Посмотреть сообщение
if (word_len > 1)
Конкретно в этой задаче отрицательных значений в ReverseStr быть не должно...
0
85 / 61 / 29
Регистрация: 15.05.2013
Сообщений: 188
05.04.2019, 10:52 9
Да, я так в общем
0
05.04.2019, 10:52
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.04.2019, 10:52
Помогаю со студенческими работами здесь

Преобразовать строку так, что порядок символов в каждом слове изменился на противоположный.
Дана строка. Группы символов, разделенных пробелами(одним или несколько) и не содержащим пробелов...

Вывести каждое предложение текста в обратном порядке
Вывести каждое предложение текста в обратном порядке

Преобразовать строку так, чтобы сначала в ней шли все цифры исходной строки, а потом – все буквы исходной строки, но в обратном порядке
1)Даны сведения о 8 фильмах: название, режиссер, страна, год выпуска, стоимость(расходы на выпуск),...

Переписать каждое предложение, расположив слова в обратном алфавитном порядке
Дан текст. Переписать каждое предложение, расположив слова в обратном алфавитном порядке.


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Проектирование и моделирование
hw_wired 28.01.2025
Введение в моделирование Моделирование представляет собой один из фундаментальных методов научного познания, который позволяет изучать объекты и явления через создание их упрощенных аналогов. В. . .
Алгоритмы и исполнители
hw_wired 28.01.2025
Введение в алгоритмы В современном мире информационных технологий алгоритмы играют основополагающую роль в решении различных задач и автоматизации процессов. Алгоритм представляет собой точную. . .
Хранение информации
hw_wired 28.01.2025
Введение: Роль систем хранения информации в современном мире В современную эпоху цифровых технологий эффективное хранение информации становится одним из ключевых факторов успешного развития любой. . .
Обработка числовой информации
hw_wired 28.01.2025
Введение в обработку числовой информации В современном мире обработка числовой информации стала неотъемлемой частью как профессиональной деятельности, так и повседневной жизни. Электронные таблицы. . .
Мультимедиа
hw_wired 28.01.2025
Введение в мультимедийные технологии В современном мире мультимедийные технологии стали неотъемлемой частью нашей жизни, проникнув во все сферы человеческой деятельности. Термин "мультимедиа". . .
Обработка текстовой информации
hw_wired 28.01.2025
Введение в обработку текстовой информации В современном мире обработка текстовой информации играет фундаментальную роль в различных сферах человеческой деятельности. Текстовые редакторы стали. . .
Обработка графической информации
hw_wired 28.01.2025
Введение в компьютерную графику Компьютерная графика стала неотъемлемой частью современного цифрового мира, пройдя впечатляющий путь развития от простейших черно-белых изображений до сложных. . .
Python в Алгоритмике: Решение задач
hw_wired 28.01.2025
Введение в Python и Алгоритмику В современном мире программирование стало неотъемлемой частью образования и профессионального развития. Python зарекомендовал себя как один из самых популярных и. . .
Компьютер как универсальное устройство для работы с информацией
hw_wired 28.01.2025
Введение в устройство компьютера Компьютер представляет собой универсальное электронное устройство, предназначенное для автоматической обработки информации. В современном мире компьютер стал. . .
Информация и информационные процессы
hw_wired 28.01.2025
Понятие информации и ее виды В современном мире информация является одним из фундаментальных понятий, пронизывающих все сферы человеческой деятельности. Под информацией понимают любые сведения об. . .
Алгоритмика
hw_wired 28.01.2025
Введение: Основы алгоритмики и её роль в информатике В современном мире программирование и алгоритмическое мышление стали неотъемлемой частью образования и профессиональной деятельности. . . .
Информационное моделирование
hw_wired 28.01.2025
Введение в информационное моделирование В современном мире информационное моделирование стало неотъемлемой частью научной, образовательной и профессиональной деятельности. Это мощный инструмент. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru