М
Молодежь
К
Компьютеры-и-электроника
Д
Дом-и-сад
С
Стиль-и-уход-за-собой
П
Праздники-и-традиции
Т
Транспорт
П
Путешествия
С
Семейная-жизнь
Ф
Философия-и-религия
Б
Без категории
М
Мир-работы
Х
Хобби-и-рукоделие
И
Искусство-и-развлечения
В
Взаимоотношения
З
Здоровье
К
Кулинария-и-гостеприимство
Ф
Финансы-и-бизнес
П
Питомцы-и-животные
О
Образование
О
Образование-и-коммуникации
romashka301
romashka301
09.05.2023 22:48 •  Информатика

Задание
У вас есть четыре документа:
a fat cat sat on a mat and ate a fat rat,
little funny fluffy cat,
the cat,
huge green crocodile.
И есть стоп-слова: “a”, “the”, “on”, “cat”. Приходит запрос: funny fat cat. Найдите все документы, где есть хотя бы одно слово из запроса. Учтите стоп-слова и не включайте их в результаты поиска. Примерный алгоритм:
Берёте слово из запроса, проверяя, что это не стоп-слово;
Ищете слово в контейнере;
Спрашиваете у контейнера, в каких документах это слово встречается. У контейнера уже есть ответ;
Добавляете индексы документов к результату;
Повторяете все шаги для каждого из слов в запросе;
Помещаете все результаты в вектор и отправляете пользователю.
Упомянутый в алгоритме контейнер — это map. Ключом в map будет слово, а значением — некий контейнер документов, в которых это слово встречается. Важно правильно записывать в словарь элементы в момент добавления документа.
Запрос funny fat cat должен сработать так:
Берёте слово “funny”, которое не входит в список стоп-слов;
Обращаетесь к словарю и находите в нём “funny”;
В словаре по ключу “funny” уже должен быть записан документ 1;
Добавляете документ 1 в результирующий вектор;
Берёте слово “fat”. Оно тоже не входит в список стоп-слов;
В словаре по ключу “fat” лежит документ 0;
Добавляете документ к результату;
“Cat” — стоп-слово, поэтому оно вам не интересно;
Возвращаете пользователю вектор с двумя элементами: 0 и 1.
Напишите функции AddDocument и FindDocuments, которые бы реализовывали решение описанной задачи. AddDocument должна заполнять индекс word_to_documents:
void AddDocument(map >& word_to_documents,
const set & stop_words,
int document_id,
const string& document);
Функция FindDocuments должна искать и выдавать требуемые идентификаторы документов в виде вектора:
vector FindDocuments(const map >& word_to_documents,
const set & stop_words,
const string& query);
В векторе с результатами не должно быть повторов. Используйте для избегания дубликатов контейнер set как промежуточный. При копировании из set в вектор результатов не меняйте порядок элементов.
Не меняйте сигнатуру FindDocuments.
СТРОКА СТОП-СЛОВ ЧИСЛО ДОКУМЕНТОВ ДОКУМЕНТ0 ДОКУМЕНТ1 ДОКУМЕНТ2 ДОКУМЕНТ3 ЗАПРОС
a the on cat 4 a fat cat sat on a mat and ate a fat rat little funny fluffy cat the cat huge green crocodile funny fat cat
Вывод (id документов):
0
1

👇
Открыть все ответы
Ответ:
Stefalove
Stefalove
09.05.2023

flag =['.*+==+*:... ',

'.*++=%%+*: ',

'.*=+*:- ',

'.*+===%%@@%%**:- ',

'.*+=%@@@%%==+++*:... ',

'.*++=%%===%%%%=+++*:--... ',

'.*++==%%%=====%%%%==++++. ',

'.*+++==%%%=%%===%%@@@%%=++*+++=+++.',

'.*==+++==%%%+*=%%%==++=%%==+*++**++==++**.',

'.**++***+==%%%+*==+==+=%@@@%%%+**+===+***.',

'.:**+*****+++***:::***+==+==++=%@@%%%=+**+==+*+++.',

'.:::*++***:::******++===+**+=++==+**==+*: ',

'.:**:**+++*****+++****+==++*::+==**==: ',

'.:**:::**+++****+++***++===+*::***:*+%=**+.',

'.:*******+++***++*::***:*+===++*:.',

'.:**+++****+*++*::***:*+===+: ',

'.:***+****++*::***::+++. ',

'.:+**+++***+*::***:::. ',

'.::***+**:::***+**::*:: ',

' :. :::::**:*++*::*. ',

' :. -:::*+**:- ',

'.:. ..:==+*- ',

' :. ..-. ',

'.:. ',

'.:. ',

' :. ',

'.:. ',

' :. ',

'.:. ',

' :. ',

' :. ']

smile =['',

'@##=',

'#%**+++**=#',

'@@@++*:+*#@@@',

'@@#*+-+%###',

'@@*+:+#@@###',

'##@@@*+++#@@##',

'##@@++**##**++#@@#',

'##@#++***=##%[email protected]@%-%##=**[email protected]@#',

'#@@@+++=+++=%===+[email protected]@#',

'#@@@++%%[email protected]@#',

'##@#++***:%@##::#@%%***[email protected]@@#',

'##@@@++%***@%***++*@@@#',

'###@@%=+.-*%***%=***%:[email protected]@@##',

'@@+*:*=%***+:+***@+*:+=#@###',

'%%%@%[email protected]%%%@',

'+**+%+**++#@@@',

'%[email protected]',

'@#@@#@']

import time

i = 0

while i != 16:

    i = int( input( 'Your select(print number 1 to 18): '))

    if i != 16:

         print("You Lose. Try again!")

         for i in range(len(smile)):

              print(smile[i])

              time.sleep(.1)

print("You completed 1 level")

for i in range(len(flag)):

    print(flag[i])

    time.sleep(.1)

i2=0

while i2 != 8:

    i2 = int( input( 'Your select(print number 1 to 10):'))

    if i2 >= 11:

         print("Error. Try again!")

    if i2 != 8:

         print("You Lose. Try again!")

   

print("You completed 2 level")

4,5(92 оценок)
Ответ:
Леша119
Леша119
09.05.2023

очищения кожи:подойдет инструмент Spot Healing Brush Tool (J) (Точечная восстанавливающая кисть) панели инструментов и выберите штамп (S), непрозрачность кисти понизьте до 30%. Этим инструментом уберите морщины под глазами. Для придания коже гладкости воспользуйтесь командой Color Range (Цветовой диапазон). Для ее открытия зайдите в меню Select > Color Range (Выделение - Цветовой диапазон). После этого нажмите в любом месте на коже и в окне цветового диапазона понизьте значение Fuzziness (Разброс) После того, как все участки, необходимые для разглаживания, будут выделены, нужно скопировать их на новый слой Ctrl + J. К этому слою примените фильтр Gaussian Blur (Размытие по Гауссу) со значением радиуса 2 пикселя.

4,8(56 оценок)
Это интересно:
Новые ответы от MOGZ: Информатика
logo
Вход Регистрация
Что ты хочешь узнать?
Спроси Mozg
Открыть лучший ответ