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

Функция определяющая сколько слов строки начинаются и заканчиваются одинаковой буквой

06.01.2020, 20:43. Показов 1700. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задача такая: Описать функцию работы со строкой символов, которая найдет, сколько из слов строки начинаются и заканчиваются одной буквой, например, "абракадабра", "сервис", "кулак" и пр.
Есть код:
Проблема в том, что в задаче нужно ОПИСАТЬ ФУНКЦИЮ. Помогите пожалуйста.
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
#include <iostream>
#include <string>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    string s;
    getline(cin, s);
 
    string temp = "";
    for (int i = 0; i <= s.size(); i++)
    {
        if ((s[i] == ' ') || (i == s.size())) {
            if (temp.size() == 0) continue;
            if (temp[0] == temp[temp.size() - 1])
                cout << temp << endl;
            temp = "";
        }
        else {
            temp += s[i];
        }
    }
 
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.01.2020, 20:43
Ответы с готовыми решениями:

Определить количество слов строки которые начинаются и заканчиваются одинаковой буквой
Задача: Описать функцию работы со строкой символов, которая найдет, сколько из слов строки начинаются и заканчиваются одной буквой,...

В строке символов найти все слова, которые начинаются и заканчиваются одинаковой буквой
Помогите сделать программу Вот задания: В строке символов найти все слова которые начинаются и заканчиваются одинаковой буквой

Определить, сколько слов в строке начинаются и заканчиваются одной и той же буквой
Решите до завтра.....хотя бы 2 плз

1
 Аватар для SomniPhobia
602 / 439 / 137
Регистрация: 22.11.2017
Сообщений: 1,407
06.01.2020, 21:42
7heWh1t3, привет! С Новым Годом!
Функция split_mod написана мной 18.07.2019.
Функция, решающая твою задачу find_count_words_has_compair_first_last_ symbol написана сейчас.
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
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <iterator>
#include <cwctype>
#include <windows.h>
 
template<typename InIt, typename OutIt>
void split_mod
(
    InIt it_begin_s,
    InIt it_end_s,
    InIt it_begin_seps,
    InIt it_end_seps,
    OutIt it_out
);
 
template<typename STR>
uint32_t find_count_words_has_compair_first_last_symbol(const std::vector<STR>& words);
 
int main()
{
    //setlocale(LC_ALL, "Rus");
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    std::wcout.imbue(std::locale("rus_rus.1251"));
    std::wcin.imbue(std::locale("rus_rus.1251"));
    std::wstring seps(L" .!?");
 
    std::wcout << L"Введите строку слов\n";
    std::wstring s;
    std::getline(std::wcin, s);
 
    std::vector<std::wstring> words;
    split_mod(s.begin(), s.end(), seps.begin(), seps.end(), std::back_inserter(words));
    /*
    //Список слов во введённой строке
    for (auto value : words)
    {
        std::wcout << L"Слово = " << value << std::endl;
    }
    std::wcout << std::endl;
    */
    uint32_t count_words_has_compair_first_last_symbol =
        find_count_words_has_compair_first_last_symbol(words);
    std::wcout << L"Введённая строка содержит " << count_words_has_compair_first_last_symbol
        << " слов, начинающихся и оканчивающихся на один и тот же символ\n";
 
    return 0;
}
 
template<typename InIt, typename OutIt>
void split_mod
(
    InIt it_begin_s,
    InIt it_end_s,
    InIt it_begin_seps,
    InIt it_end_seps,
    OutIt it_out
)
{
    if (!is_sorted(it_begin_seps, it_end_seps))
        sort(it_begin_seps, it_end_seps);
    using S = typename std::basic_string<std::iterator_traits<InIt>::value_type>;
    InIt it_old = it_begin_s;
    for (InIt it = it_begin_s; it != it_end_s; ++it)
        if (std::binary_search(it_begin_seps, it_end_seps, *it))
        {
            if (it_old != it)
                *it_out++ = S(it_old, it);
            it_old = it;
            std::advance(it_old, 1u);
        }
    if (it_old != it_end_s)
        *it_out++ = S(it_old, it_end_s);
}
 
template<typename STR>
uint32_t find_count_words_has_compair_first_last_symbol(const std::vector<STR>& words)
{
    uint32_t count = 0u;
    setlocale(LC_CTYPE, ".1251");
    for (const auto& word : words)
        count += std::towlower(word.front()) == std::towlower(word.back());
    setlocale(LC_CTYPE, "C");
    return count;
}
Миниатюры
Функция определяющая сколько слов строки начинаются и заканчиваются одинаковой буквой  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.01.2020, 21:42
Помогаю со студенческими работами здесь

Определить, сколько слов в строке начинаются и заканчиваются одной и той же буквой
Максимальный размер строки 255 символов . За имя можем рассматривать любую связь символов , которая отделена от других символов отступами...

Определить, сколько слов во введенном тексте начинаются и заканчиваются одной и той же буквой
Определить, сколько слов во введеном тексте начинаются и заканчиваются одной и той же буквой.(Слова разделены проблемами)

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

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

Посчитать число слов, которые начинаются и заканчиваются с одинаковой буквы в произвольном тексте
Помогите создать програмку каторая бы посчитала слова которые начинаются и заканчиваются с одинаковой буквы в произвольном тексте


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru