题目链接:http://poj.org/problem?id=1635

题意:给定两个由01组成的串,0代表远离根,1代表接近根。相当于每个串对应一个有根的树。然后让你判断2个串构成的树是否是同构的。

思路:首先根据01串构造出树,然后求树的最小表示法判断同构。 详情参照:https://www.byvoid.com/blog/directed-tree-bracket-sequence/

#define _CRT_SECURE_NO_DEPRECATE
#include<iostream>
#include<cstring>
#include<algorithm>
#include<string>
#include<cstdio>
#include<vector>
using namespace std;
typedef long long int LL;
const int MAXN=+;
int fa[MAXN];
char strA[MAXN],strB[MAXN];
vector<int>treeA[MAXN],treeB[MAXN];
void build(char *s,vector<int>tree[MAXN]){
int hashNum=,now=,len=strlen(s);
for(int i=;i<MAXN;i++){
tree[i].clear();
}
for(int i=;i<len;i++){
if(s[i]==''){
fa[hashNum]=now;
tree[now].push_back(hashNum);
now=hashNum++;
}
else{
now=fa[now];
}
}
}
string dfs(int now,vector<int>tree[MAXN]){
vector<string>HashC;
for(int i=;i<tree[now].size();i++){
HashC.push_back(dfs(tree[now][i],tree));
}
string Hash="(";
sort(HashC.begin(),HashC.end());
for(int i=;i<HashC.size();i++){
Hash+=HashC[i];
}
Hash+=")";
return Hash;
}
int main()
{
int t;
scanf("%d",&t);
while(t--){
scanf("%s",strA); scanf("%s",strB);
memset(fa,,sizeof(fa));build(strA,treeA);
memset(fa,,sizeof(fa));build(strB,treeB);
if(dfs(,treeA)==dfs(,treeB)){
printf("same\n");
}
else{
printf("different\n");
}
}
return ;
}

思路2:HASH,思路参照:集训队论文:杨弋《Hash在信息学竞赛中的一类应用》

题目卡的比较死。 参数不好拿捏。最好进行Double HASH比较保险

#define _CRT_SECURE_NO_DEPRECATE
#include<iostream>
#include<cstring>
#include<algorithm>
#include<string>
#include<cstdio>
#include<vector>
using namespace std;
typedef long long int LL;
typedef unsigned int uint;
const int MAXN=+;
const int MODF=1e9+;
const int MODS=1e9+;
int fa[MAXN],HF[MAXN],HS[MAXN];
char strA[MAXN],strB[MAXN];
vector<int>treeA[MAXN],treeB[MAXN];
void build(char *s,vector<int>tree[MAXN]){
int hashNum=,now=,len=strlen(s);
for(int i=;i<MAXN;i++){
tree[i].clear();
}
for(int i=;i<len;i++){
if(s[i]==''){
fa[hashNum]=now;
tree[now].push_back(hashNum);
now=hashNum++;
}
else{
now=fa[now];
}
}
}
pair<int,int> dfs(int now,vector<int>tree[MAXN]){
int HashNumF=,HashNumS=;
vector<pair<int,int> >HashC;
for(int i=;i<tree[now].size();i++){
HashC.push_back(dfs(tree[now][i],tree));
}
sort(HashC.begin(),HashC.end());
for(int i=;i<HashC.size();i++){
HashNumF=((HashNumF^HashC[i].first)*HF[i])%MODF;
HashNumS=((HashNumS^HashC[i].second)*HS[i])%MODS;
}
return make_pair(HashNumF%MODF,HashNumS%MODS);
}
int main()
{
for(int i=;i<MAXN;i++){
HF[i]=rand()%MODF;
HS[i]=rand()%MODS;
}
int t;
scanf("%d",&t);
while(t--){
scanf("%s",strA); scanf("%s",strB);
memset(fa,,sizeof(fa));build(strA,treeA);
memset(fa,,sizeof(fa));build(strB,treeB);
pair<int,int>TA=dfs(,treeA);
pair<int,int>TB=dfs(,treeB);
if(TA.first==TB.first&&TA.second==TB.second){
printf("same\n");
}
else{
printf("different\n");
}
}
return ;
}

POJ 1635 树的最小表示法/HASH的更多相关文章

  1. POJ 1635 树的最小表示法

    题目大意: 用一堆01字符串表示在树上走动的路径,0表示往前走,1表示往回走,问两种路径方式下形成的树是不是相同的树 我们可以利用递归的方法用hash字符串表示每一棵子树,然后将所有子树按照字典序排序 ...

  2. POJ1635 Subway tree systems ——(判断树的同构,树的最小表示法)

    给两棵有根树,判断是否同构.因为同构的树的最小表示法唯一,那么用最小表示法表示这两棵树,即可判断同构.顺便如果是无根树的话可以通过选出重心以后套用之前的方法. AC代码如下: #include < ...

  3. [BZOJ4337][BJOI2015]树的同构(树的最小表示法)

    4337: BJOI2015 树的同构 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1023  Solved: 436[Submit][Status ...

  4. HDU 1954 Subway tree systems (树的最小表示法)

    题意:用一个字符串表示树,0代表向下走,1代表往回走,求两棵树是否同构. 分析:同构的树经过最小表示会转化成两个相等的串. 方法:递归寻找每一棵子树,将根节点相同的子树的字符串按字典序排列,递归回去即 ...

  5. UVA 719 / POJ 1509 Glass Beads (最小表示法/后缀自动机)

    题目大意: 给出一个长度为N的字符串,求其字典序最小的循环同构. N<=10W. 算法讨论: 算法一.最小表示法.定义题. 算法二.后缀自动机. Codes: #include <iost ...

  6. 1282 时钟(最小表示法+hash)

    1282 时钟 题目来源: Codility 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 有N个时钟,每个时钟有M个指针,P个刻度.时钟是圆形的,P个刻度均分整 ...

  7. POJ 1635 Subway tree systems (树的最小表示法)

    题意:一串01序列,从一个点开始,0表示去下一个点,1表示回到上一个点,最后回到起点,遍历这棵树时每条边当且仅当走2次(来回) 给出两串序列,判断是否是同一棵树的不同遍历方式 题解:我们把每一个节点下 ...

  8. POJ1635 树的最小表示法(判断同构)

    Some major cities have subway systems in the form of a tree, i.e. between any pair of stations, ther ...

  9. luogu P5043 【模板】树同构 hash 最小表示法

    LINK:模板 树同构 题目说的很迷 给了一棵有根树 但是重新标号 言外之意还是一棵无根树 然后要求判断是否重构. 由于时无根的 所以一个比较显然的想法暴力枚举根. 然后做树hash或者树的最小表示法 ...

随机推荐

  1. func 和 actin 委托的区别

    一.[action<>]指定那些只有输入参数,没有返回值的委托 1.1定义一个委托: 比如,我们原来写委托: public delegate void myDelegate(string  ...

  2. QL Server 实用脚本

    use MyFirstDB; -- 主要内容 -- SQL Server 实用脚本 -- 1.case语句 -- 2.子查询 -- 3.连接查询 -- 4.脚本变量与流程控制(选择与循环等) -- 5 ...

  3. 【leetcode】Search in Rotated Sorted Array II(middle)☆

    Follow up for "Search in Rotated Sorted Array":What if duplicates are allowed? Would this ...

  4. quartz+spring 实现多任务动态定时器问题

    <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w ...

  5. xmpp SASL 定义

    SASL 定义 <摘抄自:xmpp_3920> [SASL]的 profiling 需求要求协议定义 供以下信息: 服务名:“xmpp” 初始序列:初始实体 供一个开放 XML 流头后,并 ...

  6. [Android Pro] 网络流量安全测试工具Nogotofail

    reference to : http://www.freebuf.com/tools/50324.html 从严重的HeartBleed漏洞到苹果的gotofail 漏洞,再到最近的SSL v3 P ...

  7. python基础——继承和多态

    python基础——继承和多态 在OOP程序设计中,当我们定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称为基类.父类或超类 ...

  8. Xcode常用代码块

    Xcode的代码片段(Code Snippets)创建自定义的代码片段,当你重用这些代码片段时,会给你带来很大的方便. 常用的: 1.strong:@property (nonatomic,stron ...

  9. 解决passwd 为普通用户设密码 不成功的方法

    echo "xxxxxxxxx"|passwd --stdin user_name #这样设置密码就可以成功!

  10. MVC – 5.MVC设计模式和.NetMVC框架

    MVC模式-设计模式 •控制器(Controller)- 负责转发请求,对请求进行处理. •视图 (View) - 界面设计人员进行图形界面设计. •模型 (Model)-业务逻辑.数据.验证规则.数 ...