2297: Carryon的字符串

Time Limit: C/C++ 1 s      Java/Python 3 s      Memory Limit: 128 MB      Accepted: 11      Submit: 24

Submit My Status

Problem Description

Carryon最近喜欢上了一些奇奇怪怪的字符,字符都是英文小写字母,但奇怪的是a可能比b小,也可能比b大,好奇怪。与此同时,他拿到了好多的字符串,可是看着很不顺眼,因为他们很乱,所以他想将这些字符串按字典序从小到大排下序,这样就好看多了。由于a可能比b小,也可能比b大,这样按常规方法肯定是不行的,幸运的是他破解了26个字母的大小顺序,这样他就开开心心的将字符串从小到大排序了。

Input

第一行输入2626个字符的大小顺序

第二行输入一个n(1≤n≤105)n(1≤n≤105)。

接下来nn行,每行一个字符串sisi,数据保证每个字符串不重复。(1≤∑i=1nlen(si)≤3×105)(1≤∑i=1nlen(si)≤3×105)

Output

将n个字符串按字典序从小到大输出。

Sample Input

abcdefghijklmnopqrstuvwxyz

5

bcda

licj

lin

aaaa

aaaaa

Sample Output

aaaa

aaaaa

bcda

licj

lin

法一:先将26个字母映射成a~z,然后在输入原串后按映射规则翻译成标准串,再通过标准串排序从而有序输出原串

#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
#include<map>
using namespace std;
map<char,char>mm;
struct node
{
string s0;//原字符串
string s1;//映射后的字符串
}p[111111];
bool cmp(node x,node y){
return x.s1<y.s1;//按标准串从小到大给结构体排序
}
int main()
{
char s[26];
scanf("%s",s);
int len=strlen(s);
for(int i=0;i<len;i++)
mm[s[i]]='a'+i;
int n;
scanf("%d",&n);
for(int i=0;i<n;i++)
{
cin>>p[i].s0;
int lenth=p[i].s0.length();
for(int j=0;j<lenth;j++)
p[i].s1+=mm[p[i].s0[j]];//翻译
//cout<<p[i].s1<<endl;
}
sort(p,p+n,cmp);//通过s1给p排序
for(int i=0;i<n;i++)
cout<<p[i].s0<<endl;
return 0;
}

法二:建立字典树,然后dfs,先按深度再按与a相差大小找并记录对应字符,每次找到尾结点输出字符串

#include<iostream>
#include<string.h>
#include<algorithm>
#include<map>
#define maxn 1111111
using namespace std;
int pos=1;
char s[26],str[maxn];
int t[maxn][26];
bool vis[maxn];
map<char,int>mm;
void insert(char *s)
{
int rt=0,len=strlen(s);
for(int i=0;i<len;i++)
{
int x=mm[s[i]];
if(!t[rt][x])
t[rt][x]=pos++;
rt=t[rt][x];
}
vis[rt]=1;
}
void dfs(int rt,int deep)
{
for(int i=0;i<26;i++)
{
if(t[rt][i])
{
str[deep]=s[i];
if(vis[t[rt][i]])//到达尾结点
{
str[deep+1]='\0';
printf("%s\n",str);
}
dfs(t[rt][i],deep+1);
}
}
return;
}
int main()
{
scanf("%s",s);
for(int i=0;i<26;i++)
mm[s[i]]=i;
int n;
scanf("%d",&n);
memset(vis,0,sizeof(vis));
for(int i=0;i<n;i++)
{
char ss[3333333];
scanf("%s",ss);
insert(ss);
}
dfs(0,0);
return 0;
}

I: Carryon的字符串排序(字典树/map映射)的更多相关文章

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

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

  2. [POJ] #1002# 487-3279 : 桶排序/字典树(Trie树)/快速排序

    一. 题目 487-3279 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 274040   Accepted: 48891 ...

  3. NYOJ 163 Phone List (字符串处理 字典树)

    题目链接 描述 Given a list of phone numbers, determine if it is consistent in the sense that no number is ...

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

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

  5. 字典树+map

    Problem Description Carryon最近喜欢上了一些奇奇怪怪的字符,字符都是英文小写字母,但奇怪的是a可能比b小,也可能比b大,好奇怪.与此同时,他拿到了好多的字符串,可是看着很不顺 ...

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

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

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

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

  8. 2017ACM暑期多校联合训练 - Team 6 1001 HDU 6096 String (字符串处理 字典树)

    题目链接 Problem Description Bob has a dictionary with N words in it. Now there is a list of words in wh ...

  9. 51nod 1095 Anigram单词【hash/map/排序/字典树】

    1095 Anigram单词 基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题  收藏  关注 一个单词a如果通过交换单词中字母的顺序可以得到另外的单词b,那么定义b ...

随机推荐

  1. 2017-2018-2 20165231 实验三 敏捷开发与XP实践

    实验报告封面 课程:Java程序设计 班级:1652班 姓名:王杨鸿永 学号:20165231 指导教师:娄嘉鹏 实验日期:2018年4月28日 实验时间:15:25 - 17:15 实验序号:实验三 ...

  2. 【Tomcat】CentOS7.0下安装多个Tomcat及其配置

    安装前所需环境 在开始安装Tomcat之前,需要安装环境JDK,并配置JAVA环境.如果不知道如何配置,可参考这篇博客:[Linux]CentOS7.0下安装JDK环境 Tomcat安装 Tomcat ...

  3. 【转】Python 面向对象(初级篇)

    [转]Python 面向对象(初级篇) 51CTO同步发布地址:http://3060674.blog.51cto.com/3050674/1689163 概述 面向过程:根据业务逻辑从上到下写垒代码 ...

  4. Go语言中的struct tag

    有时在Go的结构体定义时会看到这样的形式: type User struct { UserId int `json:"user_id" bson:"b_user_id&q ...

  5. pycharm安装numpy和scipy(window)

    win 10,64位,python3.6 用的pycharm,依次点file-settings-project-project interpreter,出现下图,(一般按正常安装流程,Package里 ...

  6. python3+selenium框架设计04-封装测试基类

    在完成了日志类封装之后,那我们就要对测试基类进行实现,在其中对一些请求再次封装,在项目下新建一个framework文件夹,在文件夹下新建Base_Page.py文件,这是用来写测试基类的文件.在项目下 ...

  7. Ubuntu16下apache2安装ssl阿里云证书

    1.用下面的命令确保ssl模块已经加载进apache: a2enmod ssl 如果你看到了“Module ssl already enabled”这样的信息就说明你成功了,如果你看到了“Enabli ...

  8. IOS应用内嵌cocos2dx游戏项目

    1.创建Cocos2d-x项目 相比于Android来说cocos2dx的iPhone环境基本不用配置,直接创建用xcode打开就可以运行. 到Cocos2d-x官方网站下载最新版本引擎. 将刚才下载 ...

  9. Excel 2013 表格自用技巧

    参考 Excel表格的基本操作(精选36个技巧) Excel2013基本用法 关于VLOOKUP函数 目录 快速复制单元格 单元格内强制换行 锁定标题行 查找重复值 万元显示 单元格中显示001 按月 ...

  10. python结合pyvmomi 监控esxi的磁盘等信息

    1.安装python3.6.6 # 安装依赖,一定要安装,否则后面可能无法安装一些python插件 yum -y install zlib-devel bzip2-devel openssl-deve ...