В строке, содержащей несколько слов, разделенных пробелом, перевернуть каждое слово - C (СИ) (72709)

Узнай цену своей работы

Формулировка задачи:

В строке, содержащей несколько слов, разделенных пробелом, перевернуть каждое слово.
Входные данные: abcde fghik lmnop Выходные данные: edcba kihgf ponml
есть код это прги на паскале, если надо могу скинуть можно сделать в java но тогда с объяснением(не знаю java)

Решение задачи: «В строке, содержащей несколько слов, разделенных пробелом, перевернуть каждое слово»

textual
Листинг программы
#include <stdio.h>
#include <ctype.h>
 
void swap(char* a, char* b) {
    char t = *a;
    *a = *b;
    *b = t;
}
 
void reverse(char* begin, char* end) {
    while (begin < end) {
        swap(begin++, end--);
    }
}
 
int getWord(char* str, char** begin, char** end) {
    for (; *str && !isalpha(*str); ++str) { ; }
    *begin = str;
 
    for (; *str && isalpha(*str); ++str) { ; }
    *end = str;
 
    return *end - *begin;
}
 
char* reverseWords(char* str) {
    char* p = str;
    char* begin, * end;
 
    while (getWord(p, &begin, &end) > 0) {
        reverse(begin, end - 1);
        p = end;
    }
 
    return str;
}
 
int main() {
    char text[] = "abcde fghik lmnop";
 
    printf("%s\n", reverseWords(text));
 
    return 0;
}

Объяснение кода листинга программы

  1. Включаются необходимые заголовочные файлы
  2. Определяются две функции: swap и reverse, которые меняют местами два указателя на символы и переворачивают строку соответственно
  3. В функции getWord ищется граница слова в строке, в которую заводятся два указателя: begin на первый символ слова и end на последний символ слова
  4. В функции reverseWords ищется начало и конец каждого слова в строке, затем вызывается функция reverse для переворота каждого слова
  5. В функции main создаётся тестовая строка и вызывается функция reverseWords, которая переворачивает слова в строке и выводит результат
  6. Возвращаемое значение функции reverseWords не используется

Оцени полезность:

13   голосов , оценка 3.769 из 5
Похожие ответы