逆序单词 HIhoCoder 1366 字典序

题意

在英文中有很多逆序的单词,比如dog和god,evil和live等等。

现在给出一份包含N个单词的单词表,其中每个单词只出现一次,请你找出其中有多少对逆序单词。

第1行:1个整数,N,表示单词数量。2≤N≤50,000。

第2..N+1行:每行1个单词,只包含小写字母,每个单词长度不超过16个字母。保证每个单词只出现一次,且不会出现回文单词(即一个单词倒序还是它自己,比如eye)。

输出第一行是个整数,表示单词表中的逆序单词的对数。

解题思路

这个是我看B站学习字典序上看到的题,基本是个模板题。详情看代码实现吧。

代码实现

字典树大体有两种实现方式,区分是从结点的建立上,一种是使用new分配空间建立,另一种是预先开辟一个数组。

下面是两种形式的代码。第二种运行比较快。

#include<bits/stdc++.h> //时间是453ms
using namespace std;
struct Node
{
Node *next[26]; //对应26个小写英文字母
int flag; //这个记录从根节点到现在这个结点组成的单词是不是存在的单词,如果有多个的话,可以记录个数。
Node()//构造函数
{
for(int i=0; i<26; i++)
next[i]=NULL;
flag=0;
}
}*root;//这个root是字典树的第一个结点,也就是树的根。 void insert(char *s) //插入操作
{
int len=strlen(s);
Node *now = root;
for(int i=len-1; i>=0; i--) //根据题目要求,这里使用逆序插入比较好。
{
int to=s[i]-'a';
if(now->next[to]==NULL) //如果没有子节点,就建立。
now->next[to]=new Node();
now=now->next[to];//然后进入到下一个单词的子节点。
}
now->flag++; //可能有多个单词
}
int fid(char *s)//查找函数
{
int len=strlen(s);
Node *now=root;
for(int i=0; i<len; i++)//这里就是正向查找了
{
int to=s[i]-'a';
if(now->next[to]==NULL)
return 0;
now=now->next[to];
}
return now->flag;//返回以这个结点为尾的单词的个数
}
void del(Node *rot) //因为使用的是new分配的空间,所以使用完毕需要进行删除。
{
for(int i=0; i<26; i++)
{
if(rot->next[i])
del(rot->next[i]);//递归形式的删除。
}
delete(rot);
}
int main()
{
int n, ans=0;
char op[20];
root = new Node();
scanf("%d",&n);
getchar();
for(int i=0; i<n; i++)
{
scanf("%s", op);
ans+=fid(op);
insert(op);
}
printf("%d\n", ans);
del(root);
return 0;
}
#include<bits/stdc++.h> //时间是242ms
using namespace std;
const int maxn=2e6+7;
int tree[maxn][27];
int flag[maxn];
int tot;
void insert(char *str)
{
int len=strlen(str);
int root=0;
for(int i=len-1; i>=0; i--)
{
int id=str[i]-'a';
if(!tree[root][id])
tree[root][id]=++tot; //类似于邻接链表的形式来建立
root=tree[root][id];
}
flag[root]++;
}
int find(char *str) //需要根据需要进行匹配
{
int len=strlen(str);
int root=0;
for(int i=0; i<len; i++)
{
int id=str[i]-'a';
if(!tree[root][id])
return 0;
root=tree[root][id];
}
return flag[root];
}
int main()
{
int n, ans=0;
char op[20];
scanf("%d",&n);
getchar();
for(int i=0; i<n; i++)
{
scanf("%s", op);
ans+=find(op);
insert(op);
}
printf("%d\n", ans);
return 0;
}

逆序单词 HIhoCoder 1366 字典树的更多相关文章

  1. HihoCoder1366 逆序单词(字典树)

    逆序单词 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在英文中有很多逆序的单词,比如dog和god,evil和live等等. 现在给出一份包含N个单词的单词表,其中每 ...

  2. TOJ3097: 单词后缀 (字典树 or map瞎搞)

    传送门 (<---可以点击的~) 时间限制(普通/Java):1000MS/3000MS     内存限制:65536KByte 描述 有些英语单词后缀都是一样的,现在我们需要从给定的一堆单词里 ...

  3. Java实现 LeetCode 648 单词替换(字典树)

    648. 单词替换 在英语中,我们有一个叫做 词根(root)的概念,它可以跟着其他一些词组成另一个较长的单词--我们称这个词为 继承词(successor).例如,词根an,跟随着单词 other( ...

  4. hiho一下 第197周 逆序单词

    1.set #include <cstdio> #include <cstdlib> #include <cstring> #include <cmath&g ...

  5. hdu 1251:统计难题(字典树,经典题)

    统计难题 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131070/65535 K (Java/Others)Total Submi ...

  6. Codeforces 633 C Spy Syndrome 2 字典树

    题意:还是比较好理解 分析:把每个单词反转,建字典树,然后暴力匹配加密串 注:然后我就是特别不理解,上面那种能过,而且时间很短,但是我想反之亦然啊 我一开始写的是,把加密串进行反转,然后单词正着建字典 ...

  7. Trie 字典树

    字典树是哈希树的变种, 它采用公用前缀的方式来提高效率, 刚开始以为公用前缀, 空间会节省, 后来想想, 空间也不是节省, 因为每一个都有26个指针(这里假设都是小写字母的话), 不过他的时间复杂度是 ...

  8. [ACM] hdu 1251 统计难题 (字典树)

    统计难题 Problem Description Ignatius近期遇到一个难题,老师交给他非常多单词(仅仅有小写字母组成,不会有反复的单词出现),如今老师要他统计出以某个字符串为前缀的单词数量(单 ...

  9. 算法学习笔记(一)C++排序函数、映射技巧与字典树

    1.头文件algorithm中有函数sort()用于排序,参数为:排序起始地址,排序结束地址,排序规则(返回bool型)例如,要将array[] = {5,7,1,2,9}升序排列,则使用: bool ...

随机推荐

  1. vue学习-day04(路由)

    目录: 1.组件传值-父组件向子组件传值和data与props的区别    2.组件传值-子组件通过事件调用向父组件传值          3.案例:发表评论.使用ref获取DOM元素和组件引用   ...

  2. 原生JS获取li中的内容

  3. TTTTTTTTTTTTTT POJ 3678 与或异或 2-SAT+强连通 模板题

    Katu Puzzle Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9129 Accepted: 3391 Descripti ...

  4. mac 下 git log 退出方法

    英文状态下按 Q (大小写无论)即可.

  5. Linux root用户密码重置,远程登陆,文件基本属性

    Linux root用户密码重置,远程登陆,文件基本属性 忘记Linux系统的root密码,linux系统忘记root密码的情况该怎么办呢?重新安装系统吗?当然不用!进入单用户模式更改一下root密码 ...

  6. Windows 下安装Apache web服务器

    1.Apache 服务器的下载 进入下载页面:http://httpd.apache.org/download.cgi 为提高下载速度,镜像选择清华大学的服务器(http://mirrors.tuna ...

  7. kibana花式查询

    在kibana提供的界面上进行操作. POST /school/student/_bulk{ "index": { "_id": 1 }}{ "nam ...

  8. [CSP-S模拟测试]:数对(线段树优化DP)

    题目传送门(内部题96) 输入格式 第一行一个整数$n$,接下来$n$行每行三个整数$a_i,b_i,w_i$. 输出格式 一行一个整数表示最大权值和. 样例 样例输入: 54 4 12 3 31 5 ...

  9. 一款新的好用的SSH工具——FinalShell,比XShell更牛逼~

    FinalShell是一体化的的服务器,网络管理软件,不仅是ssh客户端,还是功能强大的开发,运维工具,充分满足开发,运维需求.特色功能:免费海外服务器远程桌面加速,ssh加速,双边tcp加速,内网穿 ...

  10. Linux小记 -- apt-get install build-essential和yum groupinstall "Development Tools"

    Ubuntu的apt install build-essential 作用:配置Debian系统编译环境,就是下载安装支持编译Debian包的依赖/包,比如gcc等. 直接执行 #apt instal ...