【数组模拟-小顶堆的插入构造/遍历】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 ...
随机推荐
- swift 日历的制作
制作日历步骤 1.日期数据的处理,这个可以 添加 extension 解决 extension NSDate{ /*几年几月 这个月的多少天*/ class func getDaysInMonth( ...
- Jetty的安装和配置
Jetty 是一个开源的servlet容器,它为基于Java的web内容,例如JSP和servlet提供运行环境.Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布.开发人员可以将 ...
- 2019年春季学期《C语言程序设计II》课程总结
2019年春季学期<C语言程序设计II>课程总结 1.课程情况 教学内容 课堂小结 作业安排 优秀作业 备注 1.开学谈心 2.测验数据类型.运算符与表达式的自学情况,并讲解测验题目3.第 ...
- Linux DNS 服务器配置与管理
一.环境介绍: 运行软件:VMware Workstation Pro 14 系统环境:CentOS-7-x86_64-1810 二.操作配置: 1.基础知识简介 (1)域名空间 域和域名: DNS树 ...
- Bayesian machine learning
from: http://www.metacademy.org/roadmaps/rgrosse/bayesian_machine_learning Created by: Roger Grosse( ...
- 用pytorch1.0快速搭建简单的神经网络
用pytorch1.0搭建简单的神经网络 import torch import torch.nn.functional as F # 包含激励函数 # 建立神经网络 # 先定义所有的层属性(__in ...
- C++_向函数传递对象
向函数传递对象 1. 使用对象作为函数参数 对象可以作为参数传递给函数,其方法与传递其他类型的数据相同. 在向函数传递对象时,是通过传值调用传递给函数的. 因此,函数中对对象的任何修改均不影响调用该函 ...
- python 之 面向对象基础(组合和封装)
7.4 组合 解决类与类之间代码冗余问题有两种解决方案: 1.继承:描述的是类与类之间,什么是什么的关系 2.组合:描述的是类与类之间的关系,是一种什么有什么的关系 一个类产生的对象,该对象拥有一个属 ...
- Django基础十一之认证系统
一 auth模块 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这还真是个麻烦的事情呢. Django作为一个 ...
- 史上最全最新java面试题合集二(附答案)
下面小编整理了本套java面试题全集,分享给大家,希望对大家的java学习和就业面试有所帮助. 51.类ExampleA继承Exception,类ExampleB继承ExampleA. 有如下代码片断 ...