Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 19.03.2023
Сообщений: 6

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

06.05.2023, 12:54. Показов 908. Ответов 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
38167 / 21102 / 4307
Регистрация: 12.02.2012
Сообщений: 34,690
Записей в блоге: 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
38167 / 21102 / 4307
Регистрация: 12.02.2012
Сообщений: 34,690
Записей в блоге: 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
7404 / 2254 / 360
Регистрация: 10.03.2016
Сообщений: 5,213
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
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru