题解 | #[NOIP2017]图书管理员#

[NOIP2017]图书管理员

https://ac.nowcoder.com/acm/problem/16422

解题思路:通过字符串匹配,先不改变输入字符类型,通过下标索引图书库中编码最后长度为需求者图书编码的子串进行判断

nbooks,nreaders=list(map(int,input().split()))
booklist = []
readlist = []
for i in range(nbooks):
    booklist.append(input()) #字符串形式图书编码
booklist = sorted(booklist)
for j in range(nreaders):
    codelen,code = list(input().split())
    readlist.append((int(codelen),code) )#整数形式需求图书编码长度,字符串形式需求图书编码
matlist=[] #匹配最终结果

for codelen,code in readlist: #对需求图书遍历
    matelem = [] #存储是否有匹配的图书
    for j in booklist:
        if j[-codelen:]==code: #使用字符串匹配
            matelem.append(int(j))
    if len(matelem)==0: #不存在匹配数据
        matlist.append(-1)
    else: #存在匹配书籍
        matlist.append(min(matelem))
        
for elem in matlist:
    print(elem)
全部评论

相关推荐

02-11 17:51
腾讯_TEG_技术
点赞 评论 收藏
分享
牛客鼠:校友你这简历基本无敌了,春招刷刷题去冲大厂
点赞 评论 收藏
分享
01-14 19:01
吉首大学 Java
黑皮白袜臭脚体育生:加个项目吧,一般需要两个项目一业务一轮子呢,简历统一按使用了什么技术实现了什么功能解决了什么问题或提升了什么性能指标来写
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务