bzoj1819 电子词典
Description
Input
Output
将单词建立trie,对每个查询若不是单词则构造与其编辑距离为1的所有字符串并在trie查询。
由于编辑距离为1的串可能重复,一个单词可能匹配到多次,注意判重。
查询最坏时间复杂度O(M*202*26)
#include<cstdio>
#include<cstring>
int n,m;
char s[],s1[];
int nx[][],p=;
bool e[];
int d[],now=;
void insert(char*s){
int w=,c;
while(*s){
c=*s-'a';
if(nx[w][c])w=nx[w][c];
else w=nx[w][c]=p++;
s++;
}
e[w]=;
}
int find(char*s){
int w=,c;
while(*s){
c=*s-'a';
if(nx[w][c])w=nx[w][c];
else return ;
s++;
}
if(e[w]&&d[w]!=now){
d[w]=now;
return ;
}
return ;
}
int main(){
scanf("%d%d",&n,&m);
while(n--){
scanf("%s",s);
insert(s);
}
while(m--){
now++;
scanf("%s",s);
if(find(s))puts("-1");
else{
int l=strlen(s),ans=;
for(int i=;i<l;i++){
char c=s[i];
for(char a='a';a<='z';a++){
s[i]=a;
if(a!=c)ans+=find(s);
}
s[i]=c;
}
for(int i=;i<l;i++)s1[i-]=s[i];s1[l-]=;
ans+=find(s1);
for(int i=;i<l;i++){
s1[i-]=s[i-];
ans+=find(s1);
}
for(int i=;i<l;i++)s1[i+]=s[i];s1[l+]=;
for(int i=;i<=l;i++){
for(char a='a';a<='z';a++){
s1[i]=a;
ans+=find(s1);
}
s1[i]=s1[i+];
}
printf("%d\n",ans);
}
}
return ;
}
bzoj1819 电子词典的更多相关文章
- 电子词典的相关子函数db.c程序
整个电子词典是分块做的:包含的Dic_Server.c,Dic_Client.c,db.c,query.c,xprtcl.c,dict.h,xprtcl.h,dict.txt(单词文件) 下面是db. ...
- OC4_电子词典
// // MyDictionary.h // OC4_电子词典 // // Created by zhangxueming on 15/6/15. // Copyright (c) 2015年 zh ...
- C++第15周(春)项目3 - OOP版电子词典(一)
课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759.内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序中须要的相 ...
- 第14周 项目三-OOP版电子词典
做一个简单的电子词典.在文件dictionary.txt中,保存的是英汉对比的一个词典,词汇量近8000个,英文.中文释义与词性间用'\t'隔开. (1)编程序,由用户输入英文词.显示词性和中文释义. ...
- 使用Android简单实现有道电子词典
前言: 毕业设计的内容,仅仅有Java基础.没学过Android. 本着用到什么学什么.花费了10多个晚上完毕毕业设计. 当然,仅仅是简单的实线了电子词典功能,自始至终没有考虑过性能等问题. 本电子词 ...
- wxWidgets+wxSmith版电子词典
课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序须要的相关 ...
- C++第15周(春)项目3 - OOP版电子词典(二)
课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目3-OOP版电子词典](本程序须要的相关 ...
- OOP版电子词典
输入代码: /* * Copyright (c) 2014, 烟台大学计算机学院 * All rights reserved. * 文件名:sum123.cpp * 作 者:林海云 * 完毕日期:20 ...
- 第十四周(OOP版电子词典)
/* *copyright(c) 2015,烟台大学计算机学院 *All rights reserved. *文件名:第十四周(OOP版电子词典) *作者:王忠 *完毕日期:2015.6.10 *版本 ...
随机推荐
- 玩转X-CTR100 | STM32F4 l Malloc内存管理
我造轮子,你造车,创客一起造起来!塔克创新资讯[塔克社区 www.xtark.cn ][塔克博客 www.cnblogs.com/xtark/ ] 内存管理技术,即内存的申请和释放,使用X- ...
- Linux C:access()时间条件竞争漏洞
access()函数用来检查调用进程是否可以对指定的文件执行某种操作. ================================================================ ...
- L224 词汇题
Elaborate 精心的 preparations were being made for the Prime Minister’s official visit to the four forei ...
- Python学习(004)-字典{}
特点: 无序状态 键唯一 不可变类型:字符串.整型.元组 可变类型:列表.字典 字典创建 第一种: dic1={','sex':'man'} print(dic1['name']) ----- ...
- ABP .Net Core 调用异步方法抛异常A second operation started on this context before a previous asynchronous operation completed
1. 问题描述 最近使用ABP .Net Core框架做一个微信开发,同时采用了一个微信开发框架集成到ABP,在微信用户关注的推送事件里调用了一个async 方法,由于没有返回值,也没做任何处理,本 ...
- chapter02 三种决策树模型:单一决策树、随机森林、GBDT(梯度提升决策树) 预测泰坦尼克号乘客生还情况
单一标准的决策树:会根每维特征对预测结果的影响程度进行排序,进而决定不同特征从上至下构建分类节点的顺序.Random Forest Classifier:使用相同的训练样本同时搭建多个独立的分类模型, ...
- 如何创建一个基于 .NET Core 3 的 WPF 项目
在 Connect(); 2018 大会上,微软发布了 .NET Core 3 Preview,以及基于 .NET Core 3 的 WPF:同时还发布了 Visual Studio 2019 预览版 ...
- Knight Tournament 合并区间
Hooray! Berl II, the king of Berland is making a knight tournament. The king has already sent the me ...
- (4)对象的的初始化与__init__方法以及绑定方法
class OldboyStudent: # name='xxxx' # 相似的特征: school = 'oldboy' # 相似的技能 def choose_course(self): print ...
- 【vue】vue-cli 脚手架项目简介(一) - package.json
vue-cli是用来生成 vue项目的命令行工具,它的使用方法是这样的: vue init <template-name> <project-name>第二个参数 templa ...