C++ 最小堆实现

#include <bits/stdc++.h>
using namespace std;
//[4,3,5,2,1]
void tiao(vector<int>& v, int node, int leng){int left,right;int Min;while(1){left=node*2+1;  //左节点right=node*2+2;  //右节点if(left<leng){  //如果有左节点Min=min(v[node],v[left]);  //父节点和左节点取最小值if(right<leng){    //如果有右节点Min=min(Min,v[right]);   //三个节点取最小值if(Min==v[right]){  //如果最小值是右节点swap(v[node],v[right]); //交换父节点和右节点node=right; //接下来判断右节点是否符合最小堆}}if(Min==v[left]){  //如果最小值是左节点swap(v[node],v[left]); //交换父节点和左节点node=left; //接下来判断左节点是否符合最小堆}else if(Min==v[node])  //如果最小值是父节点,结束break;}else{  //如果没有左节点break;}}
}vector<int> create(vector<int>& v){int leng=v.size();  int last_node=leng/2-1;  //最后一个非叶子节点for(int n=last_node;n>=0;--n){tiao(v,n,leng);  //从右往左,从下往上调整}return v;
}using namespace std;
int main() {//int a;//cin >> a;vector<int> v={3,2,5,1,7,4};vector<int> ans=create(v);for(int i:ans){cout<<i<<" ";}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/490128.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java tostring方法_Java虚拟机如执行方法调用的(二)?

虚方法调用Java里所有非私有实例方法调用都会被编译成invokevirtual指令. 接口方法调用都会被编译成invokeinterface指令.这两种指令都属于Java虚方法的调用.在大多数情况下, Java虚拟机需要根据调用者的动态类型, 来确定虚方法调用的目标方法.这个过程被称为动态绑定. 那么相对…

[笔记]cin、cout与scanf、printf的效率差异对比分析

之前上传UVa227 puzzle时&#xff0c;好不容易AC了&#xff0c;但发现自己用时50(ms)&#xff0c;而在VJ上看到人家都是40ms、20ms&#xff0c;于是打开一个20ms的代码查看人家强在哪里。但结果研究了半天感觉差不多&#xff0c;于是想着应该不是算法的问题。然后又想到&#x…

“智联网与未来”——第14届中国信息技术年会院士精彩观点辑录

来源&#xff1a;科技导报编者按 以智慧互联为目标的智联网系统是未来信息网络的发展方向&#xff0c;将引发人类社会向智慧社会的重大变革。在中国电子学会、工业和信息化部电子科学技术委员会等主办的第14届中国信息技术年会上&#xff0c;学者热议“智联网与未来”&#xf…

什么是java的元数据_学习大数据,为什么要先学习Java?

是新朋友吗&#xff1f;记得先点蓝字关注我哦&#xff5e;今日课程菜单Java全栈开发 | Web前端H5大数据开发 | 数据分析人工智能Python | 人工智能物联网来源&#xff1a;小职(z_zhizuobiao)找我&#xff1a;✅ 解锁高薪工作 ✅ 免费获取干货教程未完待续很多人初学的第一门语言…

寻找区间质数

给定一个[left,right]的范围&#xff0c;计算这个区间内的质数的个数 思路&#xff1a;定义一个isPrime数组&#xff0c;其长度为right1&#xff0c;数组的元素为bool型&#xff0c;true代表该位置索引的数字是质数。首先数组初始化为全部true&#xff0c;然后从2开始遍历到sq…

记忆的天空:“崩塌型”记忆活动原理

作者&#xff1a;钟振余宁波大学副教授&#xff0c;工科背景&#xff0c;专注于脑科学神经信息活动机制研究。记忆是大脑活动原理的重要研究内容。相对于现代科学的高速发展&#xff0c;人类对于大脑活动原理的了解仍处在初级阶段。差不多半个多世纪之前&#xff0c;意识灵魂论…

python用途适合做什么生意-PureQuant数字货币量化交易程序化交易python量化开源框架...

什么是量化交易 量化交易起源于上世纪七十年代的股票市场&#xff0c;是指借助现代统计学和数学的方法&#xff0c;利用计算机技术来进行交易的证券投资方式。量化交易从庞大的历史数据中海选能够带来超额收益的多种“大概率”事件以制定策略&#xff0c;用数量模型验证及固化这…

调整数组顺序使奇数位于偶数前面

实现一个函数来调整该数组中数字的顺序&#xff0c;使得所有的奇数位于数组的前半部分&#xff0c;所有的偶数位于数组的后半部分&#xff0c;并保证奇数和奇数&#xff0c;偶数和偶数之间的相对位置不变。 定义两个指针tail和curr&#xff0c;tail指针首先指向第一个偶数&…

python3.5和3.7可以共存吗_centos7下Python和python3共存

一、python3.7.3安装1、下载对应的版本https://www.python.org/downloads/source/2、安装依赖的包 yum install -y gcc zlib* make libffi-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel3、解压下载的文件 tar -zxvf Python-3.7.3.tgzc…

NodeJs系列二:你好,世界

安装nodejs什么是nodejs中的模块hello&#xff0c;world转载于:https://www.cnblogs.com/humaotegong/p/5642025.html

飞天智能:阿里云的 AI 落地野心

来源&#xff1a;大叔爱吐槽CSDN当下&#xff0c;AI 业界不会否认的一个事实是&#xff0c;AI实力的比拼不再是单点的算法技术能力&#xff0c;而是从底层算法到应用平台的全面AI能力。单纯的算法&#xff0c;只是实验室里的乐趣&#xff0c;唯有结合商业的数据处理能力和技术变…

oracle把时间段转换成每一天_在家办公难适应?来看看专职外汇交易员的一天

万万没想到&#xff0c;曾经幻想的躺在床上把钱赚&#xff0c;居然成真了&#xff01;这不&#xff0c;受疫情的影响&#xff0c;不少人在家开工了&#xff01;今天是主流人群在家办公的第三天&#xff0c;然而&#xff0c;很多人表示&#xff1a;自己依然没有适应在家办公的节…

C++模板函数只声明一种类型但输入两种类型参数

具体见代码&#xff1a; #include <iostream>using namespace std;template <typename T> void Swap(T& a, T& b) {T tmp a;a b;b tmp; }int main() {int a 10;float b 20;Swap(a, b); //自动推导调用cout<<"ok"<<endl; } Sw…

python写负数_python 负数

python基础知识python_1Python解释器CPythonC语言开发的Python解释器,最广泛IPython一个交互式、功能增强的CPythonPypyPython语言写的Python解释器,JIT技术,动态编译Python代码Jpython...文章技术小阿哥2017-10-30623浏览量Python的基础语法Python的基础语法在对Python有了基础…

UVALive 7455 Linear Ecosystem (高斯消元)

Linear Ecosystem题目链接&#xff1a; http://acm.hust.edu.cn/vjudge/contest/127401#problem/B Description http://7xjob4.com1.z0.glb.clouddn.com/99b0fe905e5bd89a24c882832c93cc09 Input The first line of the input file contains an integer, n, which is the numbe…

华为诺亚方舟实验室—推荐系统中的前沿技术研究与落地报告

来源&#xff1a;专知【导读】9月6-7日&#xff0c;2019中国AI开发者大会&#xff08;AI ProCon 2019&#xff09; 在北京拉开帷幕。本次大会由新一代人工智能产业技术创新战略联盟&#xff08;AITISA&#xff09;指导&#xff0c;鹏城实验室、北京智源人工智能研究院支持&…

u盘锁电脑_程序员用U盘偷公司源码被抓;Rust 语言发布 5 周年

(给技术最前线加星标&#xff0c;每天看技术热点)综合整理&#xff1a;技术最前线(ID&#xff1a;TopITNews)参考&#xff1a;程序员的那些事、开源中国、solidot、cnBeta、腾讯科技等0、程序员用U盘偷公司源码被判刑2018年5月18日18时20分许&#xff0c;温某某在广州三七互娱科…

pytorch保存和加载模型state_dict

保存模型&#xff1a; torch.save({epoch: epoch 1,state_dict: model.state_dict(),optimizer: optimizer.state_dict(),}, datadir) 加载模型 model model_class(num_classesnum_classes) # 定义模型 state torch.load(datadir) model.load_state_dict(state[state_dic…

20幅漫画告诉你未来世界是怎样的

导读&#xff1a;在你心目中的&#xff08;不太遥远的&#xff09;未来是什么样的&#xff1f;名为Futurism Cartoons的作者绘制了一系列以“未来”为主题的漫画&#xff0c;其中多幅跟人工智能及你大数据有关&#xff0c;你们来感受一下……来源&#xff1a;大叔爱吐槽0102030…

python自动搜索请求失败_http请求 request失败自动重新尝试代码示例

本文研究的主要是http请求 request失败自动重新尝试的一个例子&#xff0c;具体如下。需求最近开发一个项目&#xff0c;要实现的一个场景是对于某个http请求&#xff0c;如果请求失败&#xff0c;需要再自动尝试几次&#xff0c;并记录异常原因便于排查代码实现#http连接有问题…