题目:Hire and Fire

  题目翻译成数据结构就是:建树,加结点,删除结点,打印结点。只有删除结点稍微复杂点,因为删除设计掉树的调整。

  首先要考虑树怎么存储才能使解题更顺手。

  1.我们要存储每个结点的孩子,父亲和名字。存储孩子是因为第一个孩子可能会“升级”,存储父亲是因为要打印,名字肯定也是要打印的;

  2.我们要知道每个结点的子树,删除结点会涉及调整;

  3.我们要知道根节点,存放CEO。

  所以我们的结点出来了,如下:

 struct Tman
{
string name;
Tman *father;
list<Tman *> sons;
};

 思路都在注释里。

  代码如下:

#include<iostream>
#include<map>
#include<list>
#include<string>
using namespace std; //存储名字,父亲,孩子就行
struct Tman
{
string name;
Tman *father;
list<Tman *> sons;
};
//key是结点名字,value是名字的子树
map<string, Tman *> hash; //根结点,指向CEO,打印是要用
Tman *root; void print(long dep, Tman *now)
{
if(now == NULL) return;
for(long i = ; i <= dep; ++i)
cout<<"+";
cout<<now->name<<endl;;
//递归打印每个孩子结点
for(list<Tman *>::iterator j = now->sons.begin(); j != now->sons.end(); ++j)
print(dep + , *j);
} void hires(string n1, string n2)
{
Tman *boss = hash[n1];//父亲的子树指针
Tman *employee = new Tman();//新建一个Tman结构体,用于存储新加入的结点
employee->name = n2;//新加入结点的名字
employee->father = boss;//n1是n2的父亲
boss->sons.push_back(employee);//把n2放入n1的孩子list中
hash[n2] = employee;//新加入的结点也要有子树
} void fire(string n1)
{
Tman *p = hash[n1];//指向n1结点的指针
hash.erase(n1);
while(p->sons.size() > )//如果要删的结点有孩子
{
p->name = p->sons.front()->name;//第一个孩子取代父亲的地位
hash[p->name] = p;//父亲的子树交给第一个孩子
p = p->sons.front();//p往下移动,始终指向孩子队列的第一个
}
p->father->sons.remove(p);//最后一个没有孩子的结点“删除”,实际上是上移了
delete p;//防止野指针
} void solve()
{
string str1,str2;
long i;
cin>>str1;
root = new Tman();
hash[str1] = root;
root->name = str1;
while(cin>>str1)
{
if(str1 == "print")
{
print(,root);
cout<<"------------------------------------------------------------"<<endl;
}
else if(str1 == "fire")
{
cin>>str2;
fire(str2);
}
else
{
cin>>str2;
cin>>str2;
hires(str1, str2);
}
}
} int main()
{
solve();
return ;
}

POJ 2003 Hire and Fire (Tree)的更多相关文章

  1. POJ 2003 Hire and Fire (多重链表 树结构 好题)

    Hire and Fire Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 2316   Accepted: 655 Desc ...

  2. HDU 1325,POJ 1308 Is It A Tree

    HDU认为1>2,3>2不是树,POJ认为是,而Virtual Judge上引用的是POJ数据这就是唯一的区别....(因为这个瞎折腾了半天) 此题因为是为了熟悉并查集而刷,其实想了下其实 ...

  3. hdu 1325 && poj 1308 Is It A Tree?(并查集)

    Description A tree is a well-known data structure that is either empty (null, void, nothing) or is a ...

  4. POJ 1308 Is It A Tree?和HDU 1272 小希的迷宫

    POJ题目网址:http://poj.org/problem?id=1308 HDU题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=1272 并查集的运用 ...

  5. POJ 1308 Is It A Tree?

    Is It A Tree? Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 18778   Accepted: 6395 De ...

  6. HDU ACM 1325 / POJ 1308 Is It A Tree?

    Is It A Tree? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  7. POJ 1308 Is It A Tree? (并查集)

    Is It A Tree? Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 24237   Accepted: 8311 De ...

  8. POJ 1308 Is It A Tree? (并查集)

    Is It A Tree? 题目链接: http://acm.hust.edu.cn/vjudge/contest/123393#problem/M Description A tree is a w ...

  9. POJ 1308 Is It A Tree?--题解报告

    Is It A Tree? Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 31092   Accepted: 10549 D ...

随机推荐

  1. 去除windows的Shift+Space 全角半角切换

    windows7下的输入法,有一个“全/半角切换”的快捷方式“Shift+Space”,我们可以通过以下方式查看到: “开始”->“控制面板”->“区域和语言”->“键盘和语言”-& ...

  2. Microsoft.Data.ConnectionUI.DataConnectionDialog

    MicrosoftVisualStudio里面的资源之数据库连接配置 这个功能的实现主要是用了Microsoft.Data.ConnectionUI.dll和Microsoft.Data.Connec ...

  3. Android开发之少去踩坑,多走捷径【转】

    作者:gzjay,腾讯MIG无线产品部 高级工程师 最近一朋友提了几个Android问题让我帮忙写个小分享,我觉得对新人还是挺有帮助的,所以有了这个小分享. 1.目前, Android APP开发完成 ...

  4. sizeof(结构体)的计算

    摘要: 经常被计算结构体的sizeof给搞晕,于是找了个时间,静下心来,搞定它. 一.为什么结构体计算这么乱? 答案是字节对齐,计算机存储系统中以Byte为单位存储数据,不同数据类型所占的空间不同,如 ...

  5. Java盲点:双重检查锁定及单例模式

    尊重原创: http://gstarwd.iteye.com/blog/692937 2004 年 5 月 01 日 所有的编程语言都有一些共用的习语.了解和使用一些习语很有用,程序员们花费宝贵的时间 ...

  6. 深入理解Java虚拟机 - 垃圾收集算法与垃圾收集器

    1. 垃圾收集算法       JVM的垃圾收集算法在不同的JVM实现中有所不同,且在平时工作中一般不会深入到收集算法,因此只对算法做较为简单的介绍.       1.1 标记-清除算法        ...

  7. BZOJ2055: 80人环游世界

    题解: 总算A掉了,各种蛋疼... int main() { freopen("input.txt","r",stdin); freopen("out ...

  8. 将archlinux 2013-06-01版,安装配置为个人工作站

    本文安装所使用的镜像为:archlinux-2013.06.01-dual.iso.首先请看看我安装完成之后的效果.图一,是第一个虚拟桌面及右键菜单图: 图二,是第二个虚拟桌面效果图.后几个虚拟桌面图 ...

  9. POJ 1149 PIGS ★(经典网络流构图)

    [题意] 有M个猪圈,每个猪圈里初始时有若干头猪.一开始所有猪圈都是关闭的.依 次来了N个顾客,每个顾客分别会打开指定的几个猪圈,从中买若干头猪.每 个顾客分别都有他能够买的数量的上限.每个顾客走后, ...

  10. 陈正冲老师对于c语言野指针的解释

    那到底什么是野指针呢?怎么去理解这个“野”呢?我们先看别的两个关于“野”的词: 野孩子:没人要,没人管的孩子:行为动作不守规矩,调皮捣蛋的孩子.野狗:没有主人的狗,没有链子锁着的狗,喜欢四处咬人. 对 ...