1 / 1 / 0
Регистрация: 10.12.2019
Сообщений: 27
1

Дан текст. Найти все слова, которые содержат символ «t» и встречаются в тексте не менее 2 раз

12.12.2019, 11:42. Показов 1027. Ответов 1
Метки нет (Все метки)

Дан текст. Найти все слова, которые содержат символ «t» и встречаются в тексте не менее 2 раз
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.12.2019, 11:42
Ответы с готовыми решениями:

Строка: Найти все слова, которые содержат символ «t» и встречаются в тексте не менее 2 раз.
1. Дан текст. Найти все слова, которые содержат символ «t» и встречаются в тексте не менее 2 раз....

Дан текст. Найти слова, в которые заданный символ входит не менее двух раз
Дан текст. Найти слова, в которые заданный символ входит не менее двух раз.

Множества. Дан текст, состоящий из строчных латинских букв. Вывести те, которые встречаются в тексте не менее 2-х раз
Дан текст, состоящий из строчных латинских букв. Вывести те, которые встречаются в тексте не менее...

Дан текст, найти слова, которые встречаются в тексте более одного раза
Дан текст, найти слова, которые встречаются в тексте более одного раза. на делфи, помогите...

1
Модератор
2181 / 1543 / 838
Регистрация: 16.10.2013
Сообщений: 4,546
Записей в блоге: 12
12.12.2019, 12:38 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
46
47
48
49
50
51
52
53
54
55
#include <iostream>
#include <vector>
#include <map>
#include <algorithm>
using namespace std;
 
// разбивает строку на слова разделенные символами из delimiters
vector<string> explodeString(const string& str, const string& delimiters = ".,. ?!-\t;:\"(){}[]"){
    vector<string> words;
    string::size_type lastPos = str.find_first_not_of(delimiters, 0);
    string::size_type pos = str.find_first_of(delimiters, lastPos);
    while (string::npos != pos || string::npos != lastPos){
        words.push_back(str.substr(lastPos, pos - lastPos));
        lastPos = str.find_first_not_of(delimiters, pos);
        pos = str.find_first_of(delimiters, lastPos);
    }
    return words;
}
 
// проверка на наличие символа symb
int haveSymbolT(string str, const char& symb = 't'){
    return count(str.begin(), str.end(), symb);
}
 
// создание ассоциативного массива, где ключ - это слово, 
// а значение - кол-во раз, которое слово встречается в тексте.
// в качестве параметра функция принимает вектор слов
map<string, int> getWordsWithT(vector<string> words){
    map<string, int> words_with_t;
    for(string word : words){
        if(haveSymbolT(word)){
            words_with_t[word]++;
        }
    }
    return words_with_t;
}
 
int main(){
    // строка для примера
    string str = "word last - world, print! split? yellow(last)split [time] {time} : time";
    
    vector<string> words = explodeString(str); // разбиваем строку на слова
    map<string, int> words_with_t = getWordsWithT(words); // подчитываем сколько раз какое слово встретилось
    
    // выводим
    cout << "words with symbol \"t\" meeting 2 and more times: " << endl;
    map<string, int>::const_iterator i;
    for(i = words_with_t.begin(); i != words_with_t.end(); ++i){
        if(i->second > 1){
            cout << i->first << " : ";
            cout << i->second << " times" << endl;
        }
    }
    return 0;
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
12.12.2019, 12:38
Помогаю со студенческими работами здесь

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

Найти все слова, в которые заданный символ входит не менее двух раз
Написать 2 программы 1) 2) Для каждой программы написать 2 варианта: 1 вариант - работа со...

Дан текстовый файл, содержащий строки. Вывести все слова в строке, которые содержат менее 4-х символов
Дан текстовый файл, содержащий строки. Вывести все слова в строке, которые содержат менее 4-х...

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru