题目大意:2567是给出一棵树,让你求出它的Prufer序列。2568时给出一个Prufer序列,求出这个树。

思路:首先要知道Prufer序列。对于随意一个无根树,每次去掉一个编号最小的叶子节点,并保存这个节点所连接的节点所得到的序列就是这棵树的Prufer序列。

这个序列有十分优雅的性质。它能与无根树一一相应。因此。两个标号一样的无根树得到的Prufer序列也一定是一样的。

此外,设一个节点的度数是d[i],那么他会在Prufer序列中出现d[i] - 1次。

2567:记录每个节点的度。依照Prufer序列的定义。最后输出队列中剩余的元素。

2568:由Prufer序列可以求出每一个点的度。把度数为1的点增加到队列中去。每次找一个队列中编号最小的。与当前Prufer序列中的数字连一条边,然后降低对应的度数。

CODE(2567):

#include <queue>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define MAX 110
using namespace std; priority_queue<int,vector<int>,greater<int> > q; int points;
int degree[MAX];
int head[MAX],total;
int next[MAX << 1],aim[MAX << 1]; int stack[MAX],top;
bool v[MAX]; inline void Initialize()
{
points = total = top = 0;
memset(degree,0,sizeof(degree));
memset(v,false,sizeof(v));
memset(head,0,sizeof(head));
} inline void Add(int x,int y)
{
next[++total] = head[x];
aim[total] = y;
head[x] = total;
} inline char GetChar()
{
char c;
do c = getchar(); while(c == ' ' || c == '\n' || c == '\r');
return c;
} inline void TopSort()
{
for(int i = 1; i <= points; ++i)
if(degree[i] == 1)
q.push(i),v[i] = true;
for(int i = 1; i <= points - 2; ++i) {
int x = q.top(); q.pop();
for(int j = head[x]; j; j = next[j]) {
if(v[aim[j]]) continue;
--degree[aim[j]];
printf("%d ",aim[j]);
if(degree[aim[j]] == 1) {
v[aim[j]] = true;
q.push(aim[j]);
}
}
}
q.pop();
printf("%d\n",q.top());
q.pop();
} int main()
{
char c;
while(GetChar() != EOF) {
Initialize();
scanf("%d",&stack[++top]);
points = stack[top];
while(top) {
c = GetChar();
if(c == '(') {
int temp;
scanf("%d",&temp);
points = max(points,temp);
Add(stack[top],temp);
Add(temp,stack[top]);
++degree[stack[top]];
++degree[temp];
stack[++top] = temp;
}
else top--;
}
if(points == 1) {
puts("");
continue;
}
TopSort();
}
return 0;
}

CODE(2568):

#include <queue>
#include <vector>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define MAX 1010
using namespace std; char s[MAX];
int src[MAX],cnt;
int degree[MAX];
int head[MAX],total;
int next[MAX],aim[MAX];
int points; inline void Initialize()
{
total = cnt = points = 0;
memset(degree,0,sizeof(degree));
memset(head,0,sizeof(head));
} inline void Add(int x,int y)
{
next[++total] = head[x];
aim[total] = y;
head[x] = total;
} inline void Decode()
{
static priority_queue<int,vector<int>,greater<int> > q;
while(!q.empty()) q.pop();
for(int i = 1; i <= points; ++i)
if(!degree[i]) q.push(i);
for(int i = 1; i <= cnt; ++i) {
int x = src[i];
int y = q.top(); q.pop();
Add(x,y); Add(y,x);
if(!--degree[x]) q.push(x);
}
//int x = q.top(); q.pop();
//int y = q.top(); q.pop();
//Add(x,y),Add(y,x);
} inline void OutPut(int x,int last)
{
if(x != 1) putchar(' ');
putchar('(');
printf("%d",x);
for(int i = head[x]; i; i = next[i]) {
if(aim[i] == last) continue;
OutPut(aim[i],x);
}
putchar(')');
} int main()
{
while(gets(s) != NULL) {
Initialize();
char *p = s;
while(*p != '\0') {
sscanf(p,"%d",&src[++cnt]);
points = max(points,src[cnt]);
++p,++p;
if(src[cnt] > 9) ++p;
}
memset(s,'\0',sizeof(s));
for(int i = 1; i <= cnt; ++i)
++degree[src[i]];
Decode();
OutPut(1,0);
puts("");
}
return 0;
}

POJ 2567 Code the Tree &amp; POJ 2568 Decode the Tree Prufer序列的更多相关文章

  1. poj 2567 Code the Tree 河南第七届省赛

    Code the Tree Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2350   Accepted: 906 Desc ...

  2. Tree Recovery POJ - 2255

    Tree Recovery POJ - 2255 根据树的前序遍历和中序遍历还原后序遍历. (偷懒用了stl的find) #include<iostream> #include<st ...

  3. ※数据结构※→☆非线性结构(tree)☆============二叉树 顺序存储结构(tree binary sequence)(十九)

    二叉树 在计算机科学中,二叉树是每个结点最多有两个子树的有序树.通常子树的根被称作“左子树”(left subtree)和“右子树”(right subtree).二叉树常被用作二叉查找树和二叉堆或是 ...

  4. [LeetCode] Verify Preorder Sequence in Binary Search Tree 验证二叉搜索树的先序序列

    Given an array of numbers, verify whether it is the correct preorder traversal sequence of a binary ...

  5. 33. Minimum Depth of Binary Tree && Balanced Binary Tree && Maximum Depth of Binary Tree

    Minimum Depth of Binary Tree OJ: https://oj.leetcode.com/problems/minimum-depth-of-binary-tree/ Give ...

  6. [LeetCode] 255. Verify Preorder Sequence in Binary Search Tree 验证二叉搜索树的先序序列

    Given an array of numbers, verify whether it is the correct preorder traversal sequence of a binary ...

  7. [leetcode]1379. Find a Corresponding Node of a Binary Tree in a Clone of That Tree

    [leetcode]1379. Find a Corresponding Node of a Binary Tree in a Clone of That Tree 链接 leetcode 描述    ...

  8. POJ 2568/ZOJ 1965 Decode the Tree

    题意:在树中,每次删去节点值最小的叶子结点. 每删去一个点,就给出与这相连的点的值,直到最后只剩下一个根结点,给这N-1个数,重新建立这个树. 思路: 给出的节点号按次序存入到数组a中,将未给出的数存 ...

  9. [欧拉回路+手动开栈] poj 1780 Code

    题目链接: http://poj.org/problem? id=1780 Code Time Limit: 1000MS   Memory Limit: 65536K Total Submissio ...

随机推荐

  1. 虚拟机VMware下CentOS6.5安装教程图文详解(VMnet8)

    (写在最前面:如果你下载的iso文件 CentOS-6.*-x86_64-minimal.iso 系列,那么需要这么安装:https://blog.csdn.net/lixianlin/article ...

  2. 超级干货,python常用函数大总结

    我们在学习python的时候,接触最多的往往则是那些函数,对于python函数,在这里为大家总结归纳了这些,如果有缺漏,还请及时留言指正哦! 话不多说,干货来袭! 1.常用内置函数:(不用import ...

  3. 浅谈LZSS与游戏图片破解

      业余游戏制作者最头疼的就是没有美工的支持了.很多业余游戏制作所使用的图片都是来自于网上的很有限的一些图片资源,然而这些图片并不能完整配套,所以业余游戏的画面往往显得单调或者搭配不协调(使用多个不属 ...

  4. unity, 由Matrix4x4提取Quaternion和Vector3 及 由Quaternion,Vector3构造Matrix4x4

    一,由Matrix4x4提取Quaternion和Vector3 Quaternion getRotationFromMatrix(Matrix4x4 m) {         return Quat ...

  5. shell脚本分析 nginx日志访问次数最多及最耗时的页面

    当服务器压力比较大,跑起来很费力时候.我们经常做站点页面优化,会去查找那些页面访问次数比较多,而且比较费时. 找到那些访问次数高,并且比较耗时的地址,就行相关优化,会取得立竿见影的效果的. 下面是我在 ...

  6. 每日英语:The First Day On A Job Is Tough Work

    Why is the first day on the job often the worst? New employees tend to be greeted with stacks of ben ...

  7. hdoj 4526 威威猫系列故事——拼车记

    威威猫系列故事——拼车记 Time Limit: 500/200 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total ...

  8. 页面跳转时候拼接在url后面的多个 参数获取

    function GetRequest() { var url = location.search; var theRequest = new Object(); if (url.indexOf(&q ...

  9. jfinal中Interceptor的使用

    一.拦截器是用于对action请求的拦截处理,发生在进入action方法体之前的拦截操作,这样方便了对请求实例做一些文章.   二.自定义.系统已有拦截器都需要实现Interceptor接口,这样才能 ...

  10. oracle 远程登录

    打开命令终端,输入命令:sqlplus /nolog 输入命令:conn sys/sys@dba as sysdba