字典树+map
Problem Description
Carryon最近喜欢上了一些奇奇怪怪的字符,字符都是英文小写字母,但奇怪的是a可能比b小,也可能比b大,好奇怪。与此同时,他拿到了好多的字符串,可是看着很不顺眼,因为他们很乱,所以他想将这些字符串按字典序从小到大排下序,这样就好看多了。由于a可能比b小,也可能比b大,这样按常规方法肯定是不行的,幸运的是他破解了26个字母的大小顺序,这样他就开开心心的将字符串从小到大排序了。
Input
第一行输入26个字符的大小顺序
第二行输入一个n(1≤n≤105)。
接下来n行,每行一个字符串si,数据保证每个字符串不重复。(1≤∑i = 1nlen(si)≤3×105)
Output
将n个字符串按字典序从小到大输出。
Sample Input
abcdefghijklmnopqrstuvwxyz
5
bcda
licj
lin
aaaa
aaaaa
Sample Output
aaaa
aaaaa
bcda
licj
lin
#include<iostream>
#include<string.h>
#include<algorithm>
#include<map>
#define maxn 1111111
using namespace std;
int pos = ;
char s[], str[maxn];
int t[maxn][];
bool vis[maxn];
map<char, int>mm;
void insert(char *s)
{
int rt = , len = strlen(s);
for (int i = ; i<len; i++)
{
int x = mm[s[i]];
if (!t[rt][x])//如果没有从rt到x的字符串前缀,插入一个
t[rt][x] = pos++;//按查询字符串的每个字符输入顺序进行标记
rt = t[rt][x];//为下一次标记准备,将当前节点作为下一次标记的上一个节点
}
vis[rt] = ;//在每次输入的一个字符串的最后一个字符标记
}
void dfs(int rt, int deep)
{
for (int i = ; i<; i++)//从第一个字符开始找(第一个字符就是最小的)
{
if (t[rt][i])//如果有从rt到i的字符串前缀
{
str[deep] = s[i];//str[]记录s[i]字符串
if (vis[t[rt][i]])//搜到s[]串的最后一个字符就输出这个字符串
{
str[deep + ] = '\0';//'\0'字符串结束符,字符串的结束标志
printf("%s\n", str);
}
dfs(t[rt][i], deep + );
}
}
return;
}
int main()
{
scanf("%s", s);
for (int i = ; i<; i++)
mm[s[i]] = i;
int n;
scanf("%d", &n);
memset(vis, , sizeof(vis));
for (int i = ; i<n; i++)
{
char ss[];
scanf("%s", ss);
insert(ss);
}
dfs(, );
return ;
} #include<iostream>
#include<cstring>
#include<algorithm>
#include<string>
#include<map>
#define N 100005
using namespace std;
map<char, char>m;
struct node
{
string s;//s是输入的字符串
string ss;//ss是映射之后的字符串
}str[N];
bool cmp(node a, node b)
{
return a.ss<b.ss;
}
int main()
{
char New[];
scanf("%s", New);
for (int i = ; i<; i++)
{
m[New[i]] = 'a' + i;//构建映射
}
int n;
scanf("%d", &n);
for (int i = ; i<n; i++)
{
cin >> str[i].s;
int len = str[i].s.length();
for (int j = ; j<len; j++)
{
str[i].ss += m[str[i].s[j]];//使用上面的映射关系
}
}
sort(str, str + n, cmp);
for (int i = ; i<n; i++)
{
cout << str[i].s << endl;
}
return ;
}
字典树+map的更多相关文章
- I: Carryon的字符串排序(字典树/map映射)
2297: Carryon的字符串 Time Limit: C/C++ 1 s Java/Python 3 s Memory Limit: 128 MB Accepted ...
- POJ 1002 487-3279(字典树/map映射)
487-3279 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 309257 Accepted: 5 ...
- poj1002 字典树+map+查询单词出现次数
487-3279 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 309235 Accepted: 55223 Descr ...
- ACM学习历程—HDU 4287 Intelligent IME(字典树 || map)
Description We all use cell phone today. And we must be familiar with the intelligent English input ...
- ZOJ 3674 Search in the Wiki(字典树 + map + vector)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4917 题意:每一个单词都一些tips单词. 先输入n个单词和他们的t ...
- hdoj 1251 字典树||map
统计难题 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131070/65535 K (Java/Others)Total Submi ...
- HDU1251 统计难题(字典树|map
Ignatius最近遇到一个难题,老师交给他很多单词(只有小写字母组成,不会有重复的单词出现),现在老师要他统计出以某个字符串为前缀的单词数量(单词本身也是自己的前缀). Input输入数据的第一部分 ...
- POJ 2503 Babelfish(map,字典树,快排+二分,hash)
题意:先构造一个词典,然后输入外文单词,输出相应的英语单词. 这道题有4种方法可以做: 1.map 2.字典树 3.快排+二分 4.hash表 参考博客:[解题报告]POJ_2503 字典树,MAP ...
- hdu1251 字典树or map
一道字典树的题,不过看起来用map更为简单 传送门 题意: 给出一堆字符串构成一个字典,求字典里以某字符串为前缀的字符串有几个 思路: 输入字符串时把字符串的前缀全部存进map并标记次数 查询时直接输 ...
随机推荐
- Luogu 3957 [NOIP2017]普及组 跳房子
写了好久,感觉自己好菜,唉…… 首先发现这个$g$的取值具有单调性,可以想到二分答案,然后考虑用$dp$来检验,这样子可以写出朴素的转移方程: 设$f_i$表示以$i$结尾的最大价值,那么有$f_i ...
- Flask框架 之 wtforms
简介 WTForms是一个支持多个web框架的form组件,主要用于对用户请求数据进行验证. 作用 生成HTML标签 form表单验证 使用 - 用户登录示例- 用户注册示例- 数据库获取数据实时更新 ...
- 编写高质量代码改善C#程序的157个建议——建议20:使用泛型集合代替非泛型集合
建议20:使用泛型集合代替非泛型集合 在建议1中我们知道,如果要让代码高效运行,应该尽量避免装箱和拆箱,以及尽量减少转型.很遗憾,在微软提供给我们的第一代集合类型中没有做到这一点,下面我们看Array ...
- VSCode调试设置
tasks.json { "version": "0.1.0", "isShellCommand": true, "args&qu ...
- Win7 WPF程序无法接受外部拖拽
最近在WPF项目中遇到一个问题.虽然选择了AllowDrop = True,但是还是无法支持从外部拖拽文件到程序,倒是内部拖拽(如从一个列表拖拽到树)和从程序拖拽到外部可以. 解决过程 1.考虑是程序 ...
- OpenResty 最佳实践 (2)
此文已由作者汤晓静授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. lua 协程与 nginx 事件机制结合 文章前部分用大量篇幅阐述了 lua 和 nginx 的相关知识,包 ...
- 动态内存分配存在的问题(内存空洞)------c++程序设计原理与实践(进阶篇)
new的问题究竟在哪里呢?实际上问题出在new和delete的结合使用上.考察下面程序中内存分配和释放过程: while(1){ Big* p=new big; //...... Small* n1= ...
- 《C#多线程编程实战》2.3 Mutex
这个真的是大坑. 如果深入研究,像是同步域,上下文这类都会出现. 但是书上有没有讲. 完全不知道什么意思. 勉勉强强讲这个Mutex的用法搞明白了. 这个是原书代码: class Program { ...
- Redhat系的Linux系统里,网络主要设置文件简介【转载】
以下是原文地址,转载请指明出处: http://blog.chinaunix.net/uid-26495963-id-3230810.html 一.配置文件详解在RHEL或者CentOS等Redhat ...
- linux系统安全及应用——账号安全(基本安全措施)
不开启桌面可以减少受攻击面 一.系统账号清理 1)非登录用户的shell改为/sbin/nologin ~] #usermod -s /sbin/nologin user1 2)锁定长期不用的账号 锁 ...