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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Locust1
0 / 0 / 0
Регистрация: 24.01.2014
Сообщений: 35
#1

ООП. Напечатать слова, отличные от последнего слова, предварительно преобразовав каждое из них по правилу - C++

26.03.2014, 22:18. Просмотров 453. Ответов 5
Метки нет (Все метки)

Напечатать слова, отличные от последнего слова, предварительно преобразовав каждое из них по правилу: удалить из слова первую букву. Использовать функции.

С помощью чего можно удалить букву из слова в строке? И как бы эту программу написать с классами и объектами используя функции?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.03.2014, 22:18
Здравствуйте! Я подобрал для вас темы с ответами на вопрос ООП. Напечатать слова, отличные от последнего слова, предварительно преобразовав каждое из них по правилу (C++):

Напечатать все слова, отличные от последнего слова, предварительно преобразовав каждое из них по заданному правилу - C++
Дан текст, содержащий от 2 до 30 слов, в каждом из которых от 2 до 10 латинских букв; между соседними словами - не менее одного пробела....

Напечатать все слова, отличные от последнего слова, предварительно преобразовав каждое из них - C++
Дан текст, содержащий от 2 до 30 слов, в каждом из которых от 2 до 10 латинских букв; между соседними словами - не менее одного пробела....

Напечатать все слова последовательности, предварительно преобразовав каждое из них по следующему правилу - C++
Задача: Код: #include <iostream> #include <string> using namespace std; int main(){ char string; char *word1 = new...

Напечатать все слова отличные от последнего слова, предварительно перенести последнюю букву в начало слова - C++
Дано текст, содержащий от 2 до 30 слов, в каждом из которых от 2 до 10 латинских букв, между соседними словами - не менее одного пробела....

Вывести все слова текста, которые отличны от последнего слова, предварительно преобразовав их - C++
Решить задачу на обработку текста, используя функции работы со строками. Предполагается, что исходным является текстовый файл. В текст...

Записать в файл слова отличные от последнего предварительно удаляя первые буквы из каждого слова - C++
Здравствуйте, помогите работаться с ошибками, мучаюсь уже две недели, и не могу понять в чем дело Суть программы пользовать вводит...

5
uburuntu
94 / 94 / 29
Регистрация: 04.10.2012
Сообщений: 189
26.03.2014, 22:27 #2
Насчет ООП не совсем понял, но удалить букву можно просто сдвинув массив чаров.
Простейшая реализация для затирания первого символа в строке s:
C++
1
2
*s = '\0';
strcat(s, s+1);
1
Locust1
0 / 0 / 0
Регистрация: 24.01.2014
Сообщений: 35
26.03.2014, 22:33  [ТС] #3
uburuntu, спасибо, вспомнил. Нужно в программе определить классы и создать объекты (объектно-ориентированное), но пока не понял что там нужно прописывать (и для чего это вообще если всё можно проще).
0
uburuntu
94 / 94 / 29
Регистрация: 04.10.2012
Сообщений: 189
26.03.2014, 22:33 #4
И да, где находятся слова? В одной строке или сразу разбиты на отдельные?
0
Locust1
0 / 0 / 0
Регистрация: 24.01.2014
Сообщений: 35
26.03.2014, 22:37  [ТС] #5
uburuntu, всё в одной строке, текст может и из 3-х слов состоять
0
uburuntu
94 / 94 / 29
Регистрация: 04.10.2012
Сообщений: 189
26.03.2014, 22:46 #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
#include <string.h>
 
int parse (char *s, const char *sep, char **words, int max_words)
    {
        char *p = s;
        int len_remain = strlen(s);
        int count = 0;
        int i_sep, i_word;
        
        while (1)
            {
                i_word = strspn(p, sep);
                for (int i = 1; i <= i_word; i++) *p++ = 0;
                words[count++] = p;
                
                if (i_word == len_remain) break;
                len_remain -= i_word;
                
                i_sep = strcspn(p, sep);
                if (i_sep == len_remain) break;
                len_remain -= i_sep;
                
                p += i_sep;
                
                if (count == max_words) break;
            }
            
        return count-1;
    }
Она разбивает входную строку s на слова, разделенные символами из sep (сепараторы, в твоем случае это просто пробел) и заносит эти слова в массив строк words. И возвращает количество получившихся слов.
Я бы на твоем месте сделал бы так: разбил строку, потом сравнивал бы words[n-1] со всеми остальными.

Но это один из способов решения, можешь придумать свой.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.03.2014, 22:46
Привет! Вот еще темы с ответами:

Напечатать слова, которые отличны от последнего слова текста, предварительно удалив из слова последнюю букву - C++
Дана последовательность содержащая от 1 до 30 слов, в каждом из которых от 1 до 5 строчных латинских букв; между соседними словами не менее...

Напечатать все слова, отличные от последнего слова строки, удалив из каждого слова первую и последнюю буквы - C++
Близиться сессия,а завтра мне сдавать 2 проги. Помогите ребят,могу даже 100 скинуть,если уж так трудно помочь. 8.Задан...

Дан текст. Напечатать его, преобразовав каждое слово по следующему правилу: удалить из слова все предыдушие вхождения последней буквы. - C++
привет всем, помогите составить програмку: Дан текст. Напечатать его, преобразовав каждое слово по следующему правилу: удалить из слова...

С++ Задан текст напечатать слова отличные от последнего слова Visual Studio - C++
Здравствуйте, вопрос такой, я написал программу через функции Её условие заключается в том, что задан текст напечатать все слова...


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

Или воспользуйтесь поиском по форуму:
6
Yandex
Объявления
26.03.2014, 22:46
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru