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的更多相关文章

  1. I: Carryon的字符串排序(字典树/map映射)

    2297: Carryon的字符串 Time Limit: C/C++ 1 s      Java/Python 3 s      Memory Limit: 128 MB      Accepted ...

  2. POJ 1002 487-3279(字典树/map映射)

    487-3279 Time Limit: 2000MS        Memory Limit: 65536K Total Submissions: 309257        Accepted: 5 ...

  3. poj1002 字典树+map+查询单词出现次数

    487-3279 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 309235   Accepted: 55223 Descr ...

  4. ACM学习历程—HDU 4287 Intelligent IME(字典树 || map)

    Description We all use cell phone today. And we must be familiar with the intelligent English input ...

  5. ZOJ 3674 Search in the Wiki(字典树 + map + vector)

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4917 题意:每一个单词都一些tips单词. 先输入n个单词和他们的t ...

  6. hdoj 1251 字典树||map

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

  7. HDU1251 统计难题(字典树|map

    Ignatius最近遇到一个难题,老师交给他很多单词(只有小写字母组成,不会有重复的单词出现),现在老师要他统计出以某个字符串为前缀的单词数量(单词本身也是自己的前缀). Input输入数据的第一部分 ...

  8. POJ 2503 Babelfish(map,字典树,快排+二分,hash)

    题意:先构造一个词典,然后输入外文单词,输出相应的英语单词. 这道题有4种方法可以做: 1.map 2.字典树 3.快排+二分 4.hash表 参考博客:[解题报告]POJ_2503 字典树,MAP ...

  9. hdu1251 字典树or map

    一道字典树的题,不过看起来用map更为简单 传送门 题意: 给出一堆字符串构成一个字典,求字典里以某字符串为前缀的字符串有几个 思路: 输入字符串时把字符串的前缀全部存进map并标记次数 查询时直接输 ...

随机推荐

  1. 2.Hive的几种常见的数据导入方式

    好久没写Hive的那些事了,今天开始写点吧.今天的话题是总结Hive的几种常见的数据导入方式,我总结为四种:(1).从本地文件系统中导入数据到Hive表:(2).从HDFS上导入数据到Hive表:(3 ...

  2. (转)那天有个小孩教我WCF[一][1/3]

    原文地址:http://www.cnblogs.com/AaronYang/p/2950931.html 既然是小孩系列,当然要有一点基础才能快速掌握,归纳,总结的一个系列,哈哈 前言: 第一篇嘛,不 ...

  3. screen工具

    1.背景 系统管理员经常需要SSH 或者telent 远程登录到Linux 服务器,经常运行一些需要很长时间才能完成的任务,比如系统备份.ftp 传输等等.通常情况下我们都是为每一个这样的任务开一个远 ...

  4. mongodb数据库学习【安装及简单增删改查】

    //@desn:mongodb数据库学习 //@desn:码字不宜,转载请注明出处 //@author:张慧源  <turing_zhy@163.com> //@date:2018/08/ ...

  5. 转:[python] pip 升级所有的包

    pip 当前内建命令并不支持升级所有已安装的Python模块. 列出当前安装的包: pip list 列出可升级的包: pip list --outdate 升级一个包: pip install -- ...

  6. 基于CentOS6定制自己的ISO安装光盘

    警告:转载请注明出处 https://www.cnblogs.com/BoyTNT/p/9322927.html  1.目标 >> 基于CentOS-6.10-x86_64-minimal ...

  7. MVC 登陆鉴权

    public ActionResult Login(string data) { var _params = JsonConvert.DeserializeAnonymousType(data, ne ...

  8. 基于verilog的FFT算法8点12位硬件实现

    FFT算法8点12位硬件实现 (verilog) 1 一.功能描述: 1 二.设计结构: 2 三.设计模块介绍 3 1.蝶形运算(第一级) 3 2.矢量角度旋转(W) 4 3.CORDIC 结果处理 ...

  9. session的获取

    Springmvc: RequestAttributes ra = RequestContextHolder.getRequestAttributes(); HttpServletRequest re ...

  10. 51 nod 1267 4个数和为0

    1267 4个数和为0 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题  收藏  取消关注 给出N个整数,你来判断一下是否能够选出4个数,他们的和为0,可以则输出& ...