POJ 3007:Organize Your Train part II
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 7561 | Accepted: 2194 |
Description
RJ Freight, a Japanese railroad company for freight operations has recently constructed exchange lines at Hazawa, Yokohama. The layout of the lines is shown in Figure 1.

Figure 1: Layout of the exchange lines
A freight train consists of 2 to 72 freight cars. There are 26 types of freight cars, which are denoted by 26 lowercase letters from "a" to "z". The cars of the same type are indistinguishable from each other, and each car's direction doesn't matter either.
Thus, a string of lowercase letters of length 2 to 72 is sufficient to completely express the configuration of a train.
Upon arrival at the exchange lines, a train is divided into two sub-trains at an arbitrary position (prior to entering the storage lines). Each of the sub-trains may have its direction reversed (using the reversal line). Finally, the two sub-trains are connected
in either order to form the final configuration. Note that the reversal operation is optional for each of the sub-trains.
For example, if the arrival configuration is "abcd", the train is split into two sub-trains of either 3:1, 2:2 or 1:3 cars. For each of the splitting, possible final configurations are as follows ("+" indicates final concatenation position):
[3:1]
abc+d cba+d d+abc d+cba
[2:2]
ab+cd ab+dc ba+cd ba+dc cd+ab cd+ba dc+ab dc+ba
[1:3]
a+bcd a+dcb bcd+a dcb+a
Excluding duplicates, 12 distinct configurations are possible.
Given an arrival configuration, answer the number of distinct configurations which can be constructed using the exchange lines described above.
Input
The entire input looks like the following.
the number of datasets = m
1st dataset
2nd dataset
...
m-th dataset
Each dataset represents an arriving train, and is a string of 2 to 72 lowercase letters in an input line.
Output
For each dataset, output the number of possible train configurations in a line. No other characters should appear in the output.
Sample Input
4
aa
abba
abcd
abcde
Sample Output
1
6
12
18
一串字符串,从中间的某一处切开,前后都可能reverse,然后这两部分前后都有可能,即正常情况下可能出现8中不同的字符串。然后问所有这些可能的字符串中有多少种不同的。
自己写hash会TLE,只能自己写。各种麻烦,函数返回局部变量的指针容易出问题,这样不行。
代码:
#include <iostream>
#include <algorithm>
#include <cmath>
#include <vector>
#include <string>
#include <cstring>
#pragma warning(disable:4996)
using namespace std; #define maxn 80 int num;
//char *wang_reverse,*sub1,*sub2,*sub3,*sub4;
//char *res1,*res2,*res3,*res4,*res5,*res6,*res7,*res8;
char sub1[80],sub2[80],sub3[80],sub4[80];
char res1[80],res2[80],res3[80],res4[80],res5[80],res6[80],res7[80],res8[80];
struct no
{
char str[maxn]; }node[maxn*maxn]; void reverse2(char *str)
{
int i,j,len;
len=strlen(str);
for(i=len-1,j=0;i>=0;i--,j++)
sub3[j]=str[i];
sub3[j]='\0';
} void reverse3(char *str)
{
int i,j,len;
len=strlen(str);
for(i=len-1,j=0;i>=0;i--,j++)
sub4[j]=str[i];
sub4[j]='\0';
} void substr(char *str,int i)
{
int j; for(j=0;j<i;j++)
sub1[j]=str[j];
sub1[j]='\0';
} void substr_rever(char *str,int i)
{
int x,j,len; len=strlen(str);
for(j=len-1,x=0;j>=i;j--,x++)
sub2[x]=str[j];
sub2[x]='\0';
} void add_str1(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res1[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res1[i]=re2[j];
i++;
}
} void add_str2(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res2[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res2[i]=re2[j];
i++;
}
} void add_str3(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res3[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res3[i]=re2[j];
i++;
}
} void add_str4(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res4[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res4[i]=re2[j];
i++;
}
} void add_str5(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res5[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res5[i]=re2[j];
i++;
}
}
void add_str6(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res6[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res6[i]=re2[j];
i++;
}
}
void add_str7(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res7[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res7[i]=re2[j];
i++;
}
}
void add_str8(char *re1,char *re2)
{
int len1=strlen(re1);
int len2=strlen(re2);
int i,j; for(i=0;i<len1;i++)
{
res8[i]=re1[i];
}
for(j=0;j<len2;j++)
{
res8[i]=re2[j];
i++;
}
} bool judge(char *str)
{
int i;
for(i=0;i<num;i++)
{
if(strcmp(str,node[i].str)==0)
{
return false;
}
}
return true;
} int main()
{
//freopen("i.txt","r",stdin);
//freopen("o.txt","w",stdout); char wang[80];
int test,i,len;
scanf("%d",&test); while(test--)
{
for(i=0;i<80;i++)
{
wang[i]='\0';
sub1[i]='\0';
sub2[i]='\0';
sub3[i]='\0';
sub4[i]='\0'; res1[i]='\0';
res2[i]='\0';
res3[i]='\0';
res4[i]='\0';
res5[i]='\0';
res6[i]='\0';
res7[i]='\0';
res8[i]='\0';
}
scanf("%s",wang);
num=0;
len=strlen(wang); for(i=1;i <= len-1;i++)
{
substr(wang,i);//sub1
substr_rever(wang,i);//sub2 reverse2(sub1);//sub3
reverse3(sub2);//sub4 add_str1(sub1,sub2);
add_str2(sub2,sub1); add_str3(sub3,sub2);
add_str4(sub2,sub3); add_str5(sub1,sub4);
add_str6(sub4,sub1); add_str7(sub3,sub4);
add_str8(sub4,sub3); if(judge(res1))
{
strcpy(node[num].str,res1);
num++;
}
if(judge(res2))
{
strcpy(node[num].str,res2);
num++;
}
if(judge(res3))
{
strcpy(node[num].str,res3);
num++;
}
if(judge(res4))
{
strcpy(node[num].str,res4);
num++;
}
if(judge(res5))
{
strcpy(node[num].str,res5);
num++;
}
if(judge(res6))
{
strcpy(node[num].str,res6);
num++;
}
if(judge(res7))
{
strcpy(node[num].str,res7);
num++;
}
if(judge(res8))
{
strcpy(node[num].str,res8);
num++;
}
}
printf("%d\n",num);
}
//system("pause");
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
POJ 3007:Organize Your Train part II的更多相关文章
- POJ 3007 Organize Your Train part II
题意: 如上图所示,将一个字符串进行分割,反转等操作后不同字符串的个数: 例如字符串abba:可以按三种比例分割:1:3:2:2:3:1 部分反转可以得到如下所有的字符串: 去掉重复可以得到六个不同的 ...
- POJ 3007 Organize Your Train part II (字典树 静态)
Organize Your Train part II Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6478 Acce ...
- Organize Your Train part II 字典树(此题专卡STL)
Organize Your Train part II Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8787 Acce ...
- poj 3007 Organize Your Train part II(二叉排序树)
题目:http://poj.org/problem?id=3007 题意:按照图示的改变字符串,问有多少种..字符串.. 思路:分几种排序的方法,,刚开始用map 超时(map效率不高啊..),后来搜 ...
- POJ 3007 Organize Your Train part II(哈希链地址法)
http://poj.org/problem?id=3007 题意 :给你一个字符串,让你无论从什么地方分割,把这个字符串分成两部分s1和s2,然后再求出s3和s4,让你进行组合,看能出来多少种不同的 ...
- poj 3007 Organize Your Train part II(静态字典树哈希)
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6700 Accepted: 1922 Description RJ Freigh ...
- poj Organize Your Train part II
http://poj.org/problem?id=3007 #include<cstdio> #include<algorithm> #include<cstring& ...
- Organize Your Train part II(hash)
http://poj.org/problem?id=3007 第一次用STL做的,TLE了,自己构造字符串哈希函数才可以.. TLE代码: #include <cstdio> #inclu ...
- Organize Your Train part II-POJ3007模拟
Organize Your Train part II Time Limit: 1000MS Memory Limit: 65536K Description RJ Freight, a Japane ...
随机推荐
- FF获6亿美元投资九城或许比贾跃亭更着急
互联网企业第九城市(以下简称"九城")确认,已透过旗下子公司与总部位于美国加州的法拉第未来公司签定协议,双方共同建立合资公司,在中国制造.营销及运营电动汽车.根据合资公司协议条款, ...
- iOS 批量上传图片的 3 种方法
AFNetworking 在去年年底升级到了 3.0.这个版本更新想必有很多好处,然而让我吃惊的是,它并没有 batch request 接口.之前的 1.x 版本.2.x 版本都实现了这个很常见的需 ...
- spring mvc绑定参数之 类型转换 有三种方式:
spring mvc绑定参数之类型转换有三种方式: 1.实体类中加日期格式化注解(上次做项目使用的这种.简单,但有缺点,是一种局部的处理方式,只能在本实体类中使用.方法三是全局的.) @DateTim ...
- Python 基础之递归 递归函数 尾递归 斐波那契
1.递归函数 定义:自己调用自己的函数递:去归:回有去有回是递归#(1)简单的递归函数def digui(n): print(n) if n > 0: digui(n- ...
- Java程序生成exe可执行文件
Java程序打包成exe可执行文件,分为两大步骤. 第一步:将Java程序通过Eclipse或者Myeclipse导成Jar包 第二步:通过exe4j讲Jar包程序生成exe可执行文件 第一步详解: ...
- 延迟加载以及mybatis一级二级缓存
延迟加载 延迟加载:在真正使用数据时才发起查询,不用的时候不查询,又叫按需查询(懒加载) 立即加载:不管用不用,只要调用方法,直接发起查询 表关系:一对多 多对一 一对一 ...
- SqlCommand的ExecuteReader方法----转载
SqlCommand的ExecuteReader方法 原创 小道 2018-08-28 17:32:01 阅读 1353 次 评论 0 条 摘要: 用于执行查询语句,并返回一个DataReader ...
- 在linux环境中配置tomcat
1.将tomcat文件上传到linux服务器上,并且解压文件. 2.创建文件夹 mkdir /usr/local/solr (这个文件夹,根据自己的喜好来创建) 3.将解压好的tomcat文件复制到 ...
- android数据的四种存储方式之一——SharedPreference
除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息.其存储位置在/data ...
- 修剪草坪 HYSBZ - 2442
在一年前赢得了小镇的最佳草坪比赛后,FJ变得很懒,再也没有修剪过草坪.现在,新一轮的最佳草坪比赛又开始了,FJ希望能够再次夺冠. 然而,FJ的草坪非常脏乱,因此,FJ只能够让他的奶牛来完成这项工作.F ...