Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 02.10.2017
Сообщений: 48

Заменить предпоследнее слово в строке звездочками

18.12.2017, 06:10. Показов 2721. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Составить программу на языке С++ для обработки строк с использованием файлов и указателей.
Вводится строка. Заменить предпоследнее слово в строке звездочками, а последнее слово перенести в начало строки.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.12.2017, 06:10
Ответы с готовыми решениями:

Удалить в строке последнее слово и удвоить предпоследнее
Доброго Времени Суток! Не могу решить 2 задачи со строками,возможно кто нибудь сможет помочь,вдруг у кого нибудь осталась задача.. Буду...

Заменить первое слово строки тремя звездочками
заменить первое слово на 3 звездачки

Первое слово текста заменить тремя звездочками
Первое слово текста заменить тремя звездочками.

2
 Аватар для Геомеханик
838 / 641 / 940
Регистрация: 26.06.2015
Сообщений: 1,409
18.12.2017, 14:43
Лучший ответ Сообщение было отмечено 99Fak99 как решение

Решение

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
#include <iostream>
#include <cctype>
#define isdelim(c) (std::isspace((c)) || std::ispunct((c)))
 
char* rep_move_word(char* s){
    char*  t = s, *w1 = NULL, *w2 = NULL;
    size_t n = 0, n1  = 0,    n2  = 0;
    //выделение слов
    do {
        if(*s && !isdelim(*s))
            ++n;
        else if(n > 0){
            n1 = n2;
            n2 = n;
            w1 = w2;
            w2 = s - n;
            n  = 0;
        }
    } while(*s++ != '\0');
 
    //предпоследнее слово заменить звёздочками
    if(w1 != NULL){ 
        for(; n1 > 0; --n1)
            *w1++ = '*';
    }
 
    //перенести последнее слово в начало строки
    if(w2 != NULL){
        char* b, *a = t;
        for(; n2 > 0; --n2, ++a){
            for(b = w2++; b > a; --b)
                std::swap(*b, *(b - 1));
        }
 
        //перенести разделитель
        for(b = w2 - 1; b > a; --b)
            std::swap(*b, *(b - 1));
    }
    return t;
}
 
int main(void){
    char s[] = "ALGOL, COBOL, PROLOG, FORTH FORTRAN";
    std::cout << rep_move_word(s) << std::endl;
    std::cin.get();
    return 0;
}
0
0 / 0 / 0
Регистрация: 02.10.2017
Сообщений: 48
31.10.2018, 06:14  [ТС]
Кто нибудь может вот это же задание сделать с файлами
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.10.2018, 06:14
Помогаю со студенческими работами здесь

Найти первое слово после запятой и предпоследнее слово в строке.
Нужно написать регулярное выражение, которое находит первое слово после запятой и предпоследнее слово в строке.

Поменять в данной строке предпоследнее слово и слово минимальной длины (первое по порядку)
Поменять в данной строке предпоследнее слово и слово минимальной длины (первое по порядку).

В символьной строке удалить предпоследнее слово
В символьной строке удалить предпоследнее слово

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

Поменять в строке местами второе и предпоследнее слово
Есть Edit(в нём записана строка), необходимо в данной строке поменять второе и предпоследнее слово местами. P.S слова разделены...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru