nyoj 685 查找字符串

2024-09-08 08:58
文章标签 字符串 查找 nyoj 685

本文主要是介绍nyoj 685 查找字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  当初一开始没做出来。
后来,学习过一段时间之后,在返回来做这道题,忽然发现,map类容器可以做。
PS:需要注意的是:此题如果用c++的输入输出的话,会超时。
O(time):gets()<  scanf() < cin。  

附上代码:

#include<stdio.h>
#include<map>
#include<string>
#include<string.h>
using namespace std;
map<string,int> mp;
char s[17];
int main()
{//freopen("a.txt","r",stdin);int t;scanf("%d",&t);while(t--){int n,m;mp.clear();scanf("%d%d",&n,&m);getchar();while(n--){gets(s);//puts(s);mp[s]++;}while(m--){gets(s);printf("%d\n",mp[s]);}}return 0;
}


百度了一下,发现还可以用字典树做。

现学了一下字典树。

结构体:

typedef struct node
{struct node *next[MAX]; /*子节点个数 */int cnt;
}Trie;
ps:

<span style="white-space: pre;">	</span>Trie *root; /*定义根节点*/
一定要建立根节点并初始化。
关键核心就三个模块:

1、建树:

void creattree()
{int l=strlen(s);node *p=root,*q;for(int i=0; i<l; i++)  //对于每一位进行处理{int id=s[i]-'+';  //找到对应的位置if(p->next[id]==NULL){q=new node;q->cnt=0;for(int j=0; j<mx; j++)q->next[j]=NULL;p->next[id]=q;}p->next[id]->cnt++;p=p->next[id];}p->cnt=-1;  //一段的结束标志。
}

2、查找:

int find()
{int l=strlen(s);node *p=root;for(int i=0; i<l; i++){int id=s[i]-'+';if(p->next[id]==NULL)return -1;          // 找不到相同串if(p->next[id]->cnt==-1){if(i==l-1)return p->cnt;   //找到了相同串elsereturn -1;   //找到了目标的子串}p=p->next[id];}return 0;   //目标为某一串子串
}

3、 大多的字典树不要需释放内存,但是如果内存不够用,该应原还树空间

<span style="color:#464646;">int deleteTrie(Trie *T)
{int i;if(T==NULL)return 0;for(i=0;i<MAX;i++){if(T->next[i]!=NULL)deleteTrie(T->next[i]);}free(T);return 0;
}</span>

第三部分还没用到,暂时还不清楚效果。


 


这篇关于nyoj 685 查找字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147672

相关文章

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图

Python中高级文本模式匹配与查找技术指南

《Python中高级文本模式匹配与查找技术指南》文本处理是编程世界的永恒主题,而模式匹配则是文本处理的基石,本文将深度剖析PythonCookbook中的核心匹配技术,并结合实际工程案例展示其应用,希... 目录引言一、基础工具:字符串方法与序列匹配二、正则表达式:模式匹配的瑞士军刀2.1 re模块核心AP