Ввести текст и список слов. Для каждого слова из заданного списка найти, сколько раз оно
встречается в тексте, и рассортировать список слов по убыванию количества их встречаемости. с++Ответы на вопрос
#define use_CRT_SECURE_NO_WARNINGS 1
#include <iostream>
#include <cstring>
using namespace std;
int main() {
setlocale(LC_ALL, "Russian");
const int N = 81;
const int N2 = 81;
int numbers[N];
int count = 0;
int count2 = 0;
string words[N];
string kwords[N2];
char the_string[N], * p;
char* next_token = nullptr;
int i = 0;
for (int k = 0; k < N; k++) {
numbers[k] = 0;
}
cout << "Введите строку:";
cin.getline(the_string, N);
p = strtok_s(the_string, " ", &next_token);
while (p != nullptr) {
words[i] = p;
i++;
p = strtok_s(nullptr, " ", &next_token);
count++;
}
cout << endl;
char the_string2[N2], * p2;
char* next_token2 = nullptr;
cout << "Введите нужные слова:";
cin.getline(the_string2, N2);
int j = 0;
p2 = strtok_s(the_string2, " ", &next_token2);
while (p2 != nullptr) {
kwords[j] = p2;
j++;
p2 = strtok_s(nullptr, " ", &next_token2);
count2++;
}
cout << endl;
for (int i = 0; i < count; i++) {
for (int j = 0; j < count2; j++) {
if (words[i] == kwords[j]) {
numbers[j] = numbers[j] + 1;
break;
}
}
}
int t; string d;
for (int j = 0; j < count2; j++) {
for (int i = 0; i < count2; i++) {
if (numbers[i] < numbers[i + 1]) {
t = numbers[i + 1];
numbers[i + 1] = numbers[i];
numbers[i] = t;
d = kwords[i + 1];
kwords[i + 1] = kwords[i];
kwords[i] = d;
}
}
}
cout << endl;
for (int i = 0; i < count2; i++) {
cout << kwords[i] << " ";
}
return 0;
}
Для выполнения этой задачи вам потребуется использовать программирование. Я предоставлю вам пример кода на Python, который решит данную задачу. В данном примере используется функция, которая принимает текст и список слов, а затем подсчитывает, сколько раз каждое слово из списка встречается в тексте и сортирует список слов по убыванию количества их встречаемости.
```python def count_and_sort_words(text, word_list): # Создаем словарь для подсчета количества встреч каждого слова word_count = {}
# Разбиваем текст на слова words_in_text = text.split()
# Проходим по каждому слову в списке for word in word_list: # Используем метод count() для подсчета количества вхождений слова в тексте count = words_in_text.count(word) word_count[word] = count
# Сортируем список слов по количеству их встречаемости sorted_word_count = sorted(word_count.items(), key=lambda x: x[1], reverse=True)
return sorted_word_count
# Пример использования функции text = "Этот текст содержит несколько слов. Несколько из них повторяются. Несколько слов." word_list = ["слово", "несколько", "из"]
result = count_and_sort_words(text, word_list)
# Выводим результат for word, count in result: print(f"{word}: {count}") ```
Пример кода разбивает текст на слова с помощью метода `split()`, затем использует метод `count()` для подсчета вхождений каждого слова из заданного списка и сохраняет результат в словаре `word_count`. Далее, список пар "слово-количество" сортируется по убыванию количества встречаемости, и результат выводится на экран.
Вы можете заменить текст и список слов в коде на свои собственные данные, чтобы получить результат для вашей конкретной задачи.
Похожие вопросы
Топ вопросов за вчера в категории Информатика
Последние заданные вопросы в категории Информатика
-
Математика
-
Литература
-
Алгебра
-
Русский язык
-
Геометрия
-
Английский язык
-
Химия
-
Физика
-
Биология
-
Другие предметы
-
История
-
Обществознание
-
Окружающий мир
-
География
-
Українська мова
-
Информатика
-
Українська література
-
Қазақ тiлi
-
Экономика
-
Музыка
-
Право
-
Беларуская мова
-
Французский язык
-
Немецкий язык
-
МХК
-
ОБЖ
-
Психология
-
Физкультура и спорт
-
Астрономия
-
Кыргыз тили
-
Оʻzbek tili
