【数组模拟-小顶堆的插入构造/遍历】PAT-L2-012.-关于堆的判断--数组模拟
L2-012. 关于堆的判断
将一系列给定数字顺序插入一个初始为空的小顶堆H[]。随后判断一系列相关命题是否为真。命题分下列几种:
- “x is the root”:x是根结点;
- “x and y are siblings”:x和y是兄弟结点;
- “x is the parent of y”:x是y的父结点;
- “x is a child of y”:x是y的一个子结点。
- (仔细观察,发现只有第二句第二个单词是“and”,除了第二个之外的句子全是第四个单词一定可以区分出来!!此中必有隐情吧,说不好出题人就是这么造数据的!!)
输入格式:
每组测试第1行包含2个正整数N(<= 1000)和M(<= 20),分别是插入元素的个数、以及需要判断的命题数。下一行给出区间[-10000, 10000]内的N个要被插入一个初始为空的小顶堆的整数 (这里是重点,所以每次读入一个新数据存入堆里后就进行调整一次)。之后M行,每行给出一个命题。题目保证命题中的结点键值都是存在的。
输出格式:
对输入的每个命题,如果其为真,则在一行中输出“T”,否则输出“F”。
输入样例:
5 4
46 23 26 24 10
24 is the root
26 and 23 are siblings
46 is the parent of 23
23 is a child of 10
输出样例:
F
T
F
T
AC题解:(开数组模拟小顶堆即可)
提醒:判断x和y是兄弟节点时,要注意y和x可能也是的;
注意越界,枚举父节点时,跑n/2即可(具体原因参考二叉树的性质)!
我写的debug()函数,输出堆的时候就是按照小顶堆的层序遍历来的!
其实用链表写着更省内存!开数组需要多开一些(一倍吧,具体自己证明多少合适!)不然会发生段错误的当数据量取上限的时候,N=1000是不够的(我试了试--段错误),见构造函数的第20行代码:“if(heap[i<<1]==-1)return ;”
因为每次访问到根节点,我用的判断方法是判断其是否还有左孩子节点!!所以————
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#include<queue>
#include<set>
#include<vector>
#include<string>
#include<map>
#define maxn 400000
#define inf 0x3f3f3f3f //L2-012. 关于堆的判断
using namespace std;
#define N 2008
int heap[N];
int flag;
int n;
void min_heap_adjust(int i){//原则:把小的元素调整上去
if(heap[i]==-)return ;
if(heap[i<<]==-)return ;
int l=i<<,r=i<<|;
if(heap[r]==-){
if(heap[i]>heap[l]){
swap(heap[i],heap[l]);
}
}else{
int minn=heap[i],j=;
if(heap[l]<minn){
j=l;minn=heap[l];
}
if(heap[r]<minn){
j=r;
}
if(j!=){
swap(heap[j],heap[i]);
min_heap_adjust(j);
}
}
}
int find_siblings(int i,int x,int y){//判断x和y是否是兄弟节点
if(flag)return ;
if(i>n/)return ;
int l=i<<,r=i<<|;
if(heap[l]==-||heap[r]==-)
return ;
if((heap[l]==x&&heap[r]==y) || (heap[r]==x&&heap[l]==y))
return flag=;
find_siblings(i<<,x,y);
find_siblings(i<<|,x,y);
return ;
}
int find_parent(int i,int x,int y){//判断x是y的父亲
if(flag)return ;
if(i>n/)return ;
int l=i<<,r=i<<|;
if(heap[i]==x){
if(heap[l]!=-){
if(heap[l]==y)return flag=;
}
if(heap[r]!=-){
if(heap[r]==y)return flag=;
}
}
find_parent(i<<,x,y);
find_parent(i<<|,x,y);
return ;
} void solve(int n){
int x,y;
flag=;//初始化一次标志数
scanf("%d",&x);
char s[];
scanf("%s",s);
if(s[]=='a'){
scanf("%d%*s%*s",&y);//求x和y是否兄弟节点
find_siblings(,x,y);
}else{
scanf("%*s%s",s);
if(s[]=='r'){
if(heap[]==x)flag=;
}
else if(s[]=='p'){//判断x是y的父亲
scanf("%*s%d",&y);
find_parent(,x,y);
}
else{
scanf("%*s%d",&y);
find_parent(,y,x);
}
}
if(flag==)printf("T\n");
else printf("F\n"); return ;
}
void debug(){
for(int i=;i<=n;i++)
printf("%d ",heap[i]);
cout<<endl;
}
int main(){
int m;
int num;
while(scanf("%d%d",&n,&m)!=EOF){
memset(heap,-,sizeof(heap));
for(int i=;i<=n;i++){
scanf("%d",&num);
heap[i]=num;
for(int j=i/;j>=;j--){
min_heap_adjust(j);
}
} // debug();
for(int i=;i<=m;i++)
solve(n);
} return ;
}
【数组模拟-小顶堆的插入构造/遍历】PAT-L2-012.-关于堆的判断--数组模拟的更多相关文章
- 【小顶堆的插入构造/遍历】PatL2-012. 关于堆的判断
L2-012. 关于堆的判断 时间限制 将一系列给定数字顺序插入一个初始为空的小顶堆H[].随后判断一系列相关命题是否为真.命题分下列几种: “x is the root”:x是根结点: “x a ...
- 面试题:给定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字
题目:给定一个长度为N的数组,其中每个元素的取值范围都是1到N.判断数组中是否有重复的数字.(原数组不必保留) 方法1.对数组进行排序(快速,堆),然后比较相邻的元素是否相同.时间复杂度为O(nlog ...
- 堆排序(大顶堆、小顶堆)----C语言
堆排序 之前的随笔写了栈(顺序栈.链式栈).队列(循环队列.链式队列).链表.二叉树,这次随笔来写堆 1.什么是堆? 堆是一种非线性结构,(本篇随笔主要分析堆的数组实现)可以把堆看作一个数组,也可以被 ...
- POJ 2442 - Sequence - [小顶堆][优先队列]
题目链接:http://poj.org/problem?id=2442 Time Limit: 6000MS Memory Limit: 65536K Description Given m sequ ...
- POJ 1456 - Supermarket - [贪心+小顶堆]
题目链接:http://poj.org/problem?id=1456 Time Limit: 2000MS Memory Limit: 65536K Description A supermarke ...
- 大顶堆与小顶堆应用---寻找前k小数
vector<int> getLeastNumber(vector<int>& arr,int k){ vector<int> vec(k,); if(== ...
- HDU 4006The kth great number(K大数 +小顶堆)
The kth great number Time Limit:1000MS Memory Limit:65768KB 64bit IO Format:%I64d & %I64 ...
- BZOJ 1150 - 数据备份Backup - [小顶堆][CTSC2007]
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1150 Time Limit: 10 Sec Memory Limit: 162 M De ...
- 《排序算法》——堆排序(大顶堆,小顶堆,Java)
十大算法之堆排序: 堆的定义例如以下: n个元素的序列{k0,k1,...,ki,-,k(n-1)}当且仅当满足下关系时,称之为堆. " ki<=k2i,ki<=k2i+1;或k ...
随机推荐
- AWS 消息服务(九)
松耦合架构 概述 使用独立的组件设计架构,降低相互依赖,当一个组件出现故障时,其他不受影响 利用ELB和SQS来打破传统服务器各层的关联,成为各层之间的中介,各层的故障和扩展均由中介自助处理 系统的耦 ...
- 最新 迅游科技java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.迅游科技等10家互联网公司的校招Offer,因为某些自身原因最终选择了迅游科技.6.7月主要是做系统复习.项目复盘.Leet ...
- 01. xadmin表单的自定义排版
xadmin表单的自定义布局(重写 get_form_layout()) apps.courses.adminx.py class NewCoursesAdmin(object): list_disp ...
- 路由(Routing)
路由(Routing) ASP.NET Core MVC 路由是建立在ASP.NET Core 路由的,一项强大的URL映射组件,它可以构建具有理解和搜索网址的应用程序.这使得我们可以自定义应用程序 ...
- 如何取到el-select中的label
在el-select中我们一般都是取到value的值,但是有时候我们需要value和label都需要.那怎么方便的取到呢 在网上经常有ref="cascader"这个方法,但是经过 ...
- 怎么对10亿数据量级的mongoDB作高效的全表扫描
转自:http://quentinxxz.iteye.com/blog/2149440 一.正常情况下,不应该有这种需求 首先,大家应该有个概念,标题中的这个问题,在大多情况下是一个伪命题,不应该被提 ...
- teamviewer远程控制程序免费版百度云下载
TeamViewer是一个远程共享桌面软件,使远程传输变得简单快速,远程访问安全可靠,能在任何防火墙后台进行远程控制.只需用户在两台计算机上同时运行这个软件就可以开始工作.使用时关闭杀毒软件,防止误报 ...
- Filter讲解4
想要 浏览更多Fiddler内容:请点击进入Fiddler官方文档 阅读目录: 一.使用.NET代码扩展Fiddler 二.实现Fiddler接口 三.创建Fiddler扩展项目 四.在扩展程序选项卡 ...
- 查看php和apache配置成功的方法
PHP配置文件是php.ini 检查php是否配置成功,在wamp/www根目录写一个phpinfo.php文件,内容为 <?php phpinfo(); ?> 然后可以打开网页输入l ...
- 如何加入 Skype for Business 会议?
参加一个线上培训,收到了Skype的参会地址,是这个样子的 然后就是一脸懵逼的不知道怎么参加会议了.找了半天终于在同事的帮助下参加成功. 我的参加方法:在Window上用Skype for Busin ...