字典树+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并标记次数 查询时直接输 ...
随机推荐
- 执行CUnit测试出错
est/test_fifo.test: error while loading shared libraries: libcunit.so.1: cannot open shared object f ...
- 各种RNAseq原理
RNA Sequencing Methods Low-Level RNA Detection CEL-Seq CirSeq CLaP CytoSeq Digital RNA Sequencing DP ...
- 39.FORMAT() 函数
FORMAT() 函数 FORMAT 函数用于对字段的显示进行格式化. SQL FORMAT() 语法 SELECT FORMAT(column_name,format) FROM table_nam ...
- numpy ndarray 返回 index 问题
经常遇到需要返回满足条件的index. python中没有which函数,但有列表推导式, 可以实现类似功能 y= np.array([3,2,5,20]) yOut[131]: array([ 3, ...
- Oracle——单行函数
两种 SQL 函数 单行函数 字符函数 大小写控制函数 SELECT employee_id, last_name, department_id FROM employees WHERE last_n ...
- SQL聚集索引和非聚集索引的区别
其实对于非专业的数据库操作人员来讲,例如软件开发人员,在很大程度上都搞不清楚数据库索引的一些基本知识,有些是知其一不知其二,或者是知其然不知其所以然.造成这种情况的主要原因我觉的是行业原因,有很多公司 ...
- python DDT读取excel测试数据
转自:http://www.cnblogs.com/nuonuozhou/p/8645129.html ddt 结合单元测试一起用 ddt(data.driven.test):数据驱动测试 由外部 ...
- 最全面的jackson json 技术
http://www.360doc.com/content/12/0429/09/7656232_207428466.shtml
- [原创]Java源代码学习
一.一些关键字 方法声明中的native:调用本地方法,该方法一般是用C或者C++写的 变量声明中的transient:在序列化过程中会忽略该变量,即不进行序列化保存 变量声明中的volatile:编 ...
- java多线程的基本介绍
Java多线程 1.进程与线程 进程是程序的一次动态执行过程,它需要经历从代码加载,代码执行到执行完毕的一个完整的过程,这个过程也是进程本身从产生,发展到最终消亡的过程.多进程操作系统能同时达运行多个 ...