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

В словах наибольшей длины удалить среднюю букву (средние буквы) - C++

Восстановить пароль Регистрация
 
alexsandrovna
0 / 0 / 0
Регистрация: 02.06.2014
Сообщений: 6
02.06.2014, 19:00     В словах наибольшей длины удалить среднюю букву (средние буквы) #1
В тексте все слова разделены пробелами и знаками
препинания. Напечатать все слова, предварительно выполнив
преобразования: в словах наибольшей длины
удалить среднюю (средние) букву.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.06.2014, 19:00     В словах наибольшей длины удалить среднюю букву (средние буквы)
Посмотрите здесь:

Дано слово. Если длина нечетная, то удалить среднюю букву, в противном случае две буквы C++
Строки. Удалить слова наибольшей длины C++
Удалить среднею букву в нечетных словах текста C++
В словах заданной строки, имеющих нечетную длину, удалить среднюю букву C++
Задан текст. Удалить в словах первую букву C++
Удалить из слова средние буквы C++
Изъять среднюю букву из каждого слова нечетной длины C++
C++ Удалить среднюю букву в нечетных словах текста

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
GuGo1991
267 / 261 / 93
Регистрация: 02.08.2012
Сообщений: 609
02.06.2014, 19:37     В словах наибольшей длины удалить среднюю букву (средние буквы) #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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <iostream>
#include <vector>
#include <conio.h>
 
int main()
{
    std::string str;
    std::cout << "Type some text: ";
    getline(std::cin, str);
    char* chStr = new char[str.size() + 1];
    std::strcpy(chStr, str.c_str());
    std::vector<std::string> arr;
    char* p = std::strtok(chStr, " ,.!;?");
    while(p != NULL)
    {
        arr.push_back(p);
        p = strtok(NULL, " ,.!;?");
    }
    
    int max_size = arr[0].size();
    
    for(int i = 0; i < arr.size(); i++)
    {
        if(max_size < arr[i].size())
            max_size = arr[i].size();
    }
    
    for(int i = 0; i < arr.size(); i++)
    {
        if(max_size == arr[i].size())
        {
            if(max_size % 2)
                arr[i] = arr[i].replace(max_size / 2, 1, "");
            else
                arr[i] = arr[i].replace(max_size / 2 - 1, 2, "");
        }
    }
    
    for(int i = 0; i < arr.size(); i++)
        std::cout << arr[i] << " ";
    
    std::cout << "\nOperation succeeded\n";
    getch();
    return 0;
}
Yandex
Объявления
02.06.2014, 19:37     В словах наибольшей длины удалить среднюю букву (средние буквы)
Ответ Создать тему
Опции темы

Текущее время: 14:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru