0 / 0 / 0
Регистрация: 19.03.2023
Сообщений: 6

Определить подходит ли слово под шаблон

06.05.2023, 12:54. Показов 915. Ответов 5

Студворк — интернет-сервис помощи студентам
Будем рассматривать слова из больших латинских букв и шаблоны, состоящие из больших латинских букв и символов «?» и «*». Говорят, что слово подходит под шаблон, если в шаблоне можно заменить каждый символ «?» на большую латинскую букву, а каждый символ «*» – на последовательность (возможно, пустую) больших латинских букв, так, чтобы получилось требуемое слово. Требуется написать программу, определяющую, подходит ли слово под шаблон.

Входные данные
В первых двух строках входного файла записаны шаблон и слово: в одной строке записан шаблон – последовательность больших латинских букв, «?» и «*», в другой – слово, состоящее только из больших латинских букв. Обе строки входного файла не превышают 255 символов.
Выходные данные
На выходе необходимо вывести слово «YES», если слово подходит под шаблон и «NO» в противном случае.

Пример
ABBCDA
A*CDA

YES
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.05.2023, 12:54
Ответы с готовыми решениями:

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

Написать программу, определяющую, подходит ли слово под шаблон
Задача «Шаблоны» Будем рассматривать слова из больших латинских букв и шаблоны, состоящие также из больших латинских букв и символов «?»...

Определить, подходит ли данная строка под ее шаблон
Здравствуйте, помогите решить пожалуйста! В первой строке записан шаблон состоящий из маленьких латинских символов и знаков...

5
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
06.05.2023, 13:43
Шаблон, так шаблон
Python
1
2
3
4
5
import re
 
z = 'ABBCDA'
v = 'A*CDA'
print(['no', 'yes'][bool(re.fullmatch(re.sub(r'(?=[*?])', '[A-Z]', v), z))])
3
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38171 / 21106 / 4307
Регистрация: 12.02.2012
Сообщений: 34,699
Записей в блоге: 14
06.05.2023, 19:44
iSmokeJC, это изюм...
1
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
06.05.2023, 19:46
Catstail, разумеется! Зато какой вкусный!!!
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38171 / 21106 / 4307
Регистрация: 12.02.2012
Сообщений: 34,699
Записей в блоге: 14
06.05.2023, 20:02
Как примитивный вариант:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
def stencil(stri,patt):
    
    if len(patt)==0:
        return True
        
    ss=stri[0]
    pp=patt[0]
    
    if (ss == pp) or (pp == '?'):
        return stencil(stri[1:],patt[1:])
        
    if (pp == "*"):
        nn=patt[1]
        k=stri.find(nn)
        if k == -1:
            return False
        return stencil(stri[k:],patt[1:])
    
    return False    
 
print("YES" if stencil("ABBCDA","A*CDA") else "NO")        
print("YES" if stencil("ABBCDA","A?CDA") else "NO")
print("YES" if stencil("ABBCDA","A??CDA") else "NO")
3
Любознательный
 Аватар для YuS_2
7405 / 2255 / 360
Регистрация: 10.03.2016
Сообщений: 5,215
06.05.2023, 20:49
Python
1
2
3
4
import fnmatch as fn
str1 = "ABBCDA"
patt = "A*CDA"
print('YES' if fn.fnmatchcase(str1,patt) else 'NO')
5
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.05.2023, 20:49
Помогаю со студенческими работами здесь

Проверка, подходит ли строка под шаблон
Всем доброго времени суток! В первой строке записан шаблон, состоящий из маленьких латинских символов и звездочек "*", которые...

Поле чудес (мини-игра) - подобрать слово под шаблон
Доброго времени суток! Помогите пожалуйста с написанием вот такой мини игрушки в консоли на "чистом" Си: В слове угаданы...

мт: подходит ли слово алфавиту?
Моя задача - программно реализовать машину Тьюринга, которая проверит, является ли слово на входе словом данного языка. Если нет - стереть...

Подходит ли видяха под пк?
Добрый вечер, уважаемые. Решил взять видеокарту Inno3D Geforce GTS 240 green, 1024 mb, 256 bit. Да-да, знаю что старая, dx11 не...

Как в RichEdit определить слово под мышкой при клике?
В общем сабж. Есть ричэдит, есть клик мышкой по нему, например правой кнопкой. При этом возникнет событие OnContextPopup При ...


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

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

Новые блоги и статьи
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