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.-关于堆的判断--数组模拟的更多相关文章

  1. 【小顶堆的插入构造/遍历】PatL2-012. 关于堆的判断

    L2-012. 关于堆的判断 时间限制   将一系列给定数字顺序插入一个初始为空的小顶堆H[].随后判断一系列相关命题是否为真.命题分下列几种: “x is the root”:x是根结点: “x a ...

  2. 面试题:给定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字

    题目:给定一个长度为N的数组,其中每个元素的取值范围都是1到N.判断数组中是否有重复的数字.(原数组不必保留) 方法1.对数组进行排序(快速,堆),然后比较相邻的元素是否相同.时间复杂度为O(nlog ...

  3. 堆排序(大顶堆、小顶堆)----C语言

    堆排序 之前的随笔写了栈(顺序栈.链式栈).队列(循环队列.链式队列).链表.二叉树,这次随笔来写堆 1.什么是堆? 堆是一种非线性结构,(本篇随笔主要分析堆的数组实现)可以把堆看作一个数组,也可以被 ...

  4. POJ 2442 - Sequence - [小顶堆][优先队列]

    题目链接:http://poj.org/problem?id=2442 Time Limit: 6000MS Memory Limit: 65536K Description Given m sequ ...

  5. POJ 1456 - Supermarket - [贪心+小顶堆]

    题目链接:http://poj.org/problem?id=1456 Time Limit: 2000MS Memory Limit: 65536K Description A supermarke ...

  6. 大顶堆与小顶堆应用---寻找前k小数

    vector<int> getLeastNumber(vector<int>& arr,int k){ vector<int> vec(k,); if(== ...

  7. HDU 4006The kth great number(K大数 +小顶堆)

    The kth great number Time Limit:1000MS     Memory Limit:65768KB     64bit IO Format:%I64d & %I64 ...

  8. BZOJ 1150 - 数据备份Backup - [小顶堆][CTSC2007]

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1150 Time Limit: 10 Sec Memory Limit: 162 M De ...

  9. 《排序算法》——堆排序(大顶堆,小顶堆,Java)

    十大算法之堆排序: 堆的定义例如以下: n个元素的序列{k0,k1,...,ki,-,k(n-1)}当且仅当满足下关系时,称之为堆. " ki<=k2i,ki<=k2i+1;或k ...

随机推荐

  1. windows下 pip下载包到指定目录

    pip download -r requirements.txt -d G:\PythonVirtualenv\packages python setup.py install

  2. SQL Server数据同步到Oracle

    一.分别配置SQL Server和oracle数据库的连接信息并测试连接. 二.新增数据同步任务,配置规则,运行任务,查看日志. 支持数据自动定时抽取,转换,汇聚同步.支持一对多,多对一,多对多等数据 ...

  3. Swoole练习 UDP

    UDP 服务代码 <?php //创建Server对象,监听 127.0.0.1:9502端口,类型为SWOOLE_SOCK_UDP $serv = new swoole_server(&quo ...

  4. docker 使用阿里云镜像加速

    1.登录阿里云 2.进入控制台 3.搜索 “容器镜像服务” 下拉点击 “镜像加速器” 复制自己的私有地址 进入自己的docker宿主机器(替换下面的地址为自己的私有地址) 修改daemon配置文件/e ...

  5. SUPPA 可变剪切分析

      SUPPA是一款通过转录本定量来获取可变剪切定量结果的软件.转录本的定量方式有很多,例如count,FPKM, TPM等,作者建议使用TPM,因为先均一化了基因的长度,然后均一化了测序的深度.同时 ...

  6. dotnet core use MangoDB

    安装MangoDB 同样我这边再次使用Docker, 方便快捷: # 拉取镜像 docker pull mongo # 运行镜像 docker run -d -p 37017:27017 --name ...

  7. Python31之类和对象1(三大特征:多封继——多疯子)

    一.对象: Python即是面向对象的编程也是面向过程的编程语言,其内部可谓是无处不对象,我们所熟知的列表,字符串等工厂函数本质上都是对象.对象其实是对属性和方法的封装. 属性是对象的静态特征 方法是 ...

  8. 使用keepalived实现kubenetes apiserver高可用

    # 安装 nginx yum install nginx -y # 配置nginx4层代理 /etc/nginx/nginx.conf stream { upstream kube-apiserver ...

  9. golang之文件结尾错误(EOF)

    函数经常会返回多种错误,这对终端用户来说可能会很有趣,但对程序而言,这使得情况变得复杂.很多时候,程序必须根据错误类型,作出不同的响应.让我们考虑这样一个例子:从文件中读取n个字节.如果n等于文件的长 ...

  10. 20191113-Linux+robotframework+jenkins配置自动化测试2

    第八步:配置jenkins 安装JDK a)     yum install java-1.8.0-openjdk java-1.8.0-openjdk-devel 配置环境变量 a)     vi ...