当前位置: 首页 > news >正文

西安大型网站建设公司排名网站后台的关键词

西安大型网站建设公司排名,网站后台的关键词,俄罗斯军事新闻最新消息,如何做响应式网站视频教程总时间限制: 1000ms 内存限制: 65536kB 描述 给定初始整数顺串,以及大小固定并且初始元素已知的二叉最小堆(为完全二叉树或类似完全二叉树,且父元素键值总小于等于任何一个子结点的键值),要求利用堆实现置换选择排序&a…

总时间限制: 1000ms 内存限制: 65536kB
描述
给定初始整数顺串,以及大小固定并且初始元素已知的二叉最小堆(为完全二叉树或类似完全二叉树,且父元素键值总小于等于任何一个子结点的键值),要求利用堆实现置换选择排序,并输出第一个顺串。例如给定初始顺串29,14,35,13,以及堆(记为16 19 31 25 21 56 40), 置换选择排序得到的第一个顺串为16 19 21 25。

在这里插入图片描述

输入

第一行包含两个整数,m为初始顺串的数的个数,n为二叉最小堆的大小
第二行包含m个整数,即初始顺串
第三行包含n个整数,即已经建好的堆的元素(有序,按照从堆顶到堆底,从左到右的顺序)

输出

输出包含一行,即第一个顺串。

样例输入

4 7
29 14 35 13
16 19 31 25 21 56 40

样例输出

16 19 21 25

思路

  1. 我们知道这是一个小根堆,堆顶元素是最小的,我们可以将堆顶元素取出,将其放入res数组中,然后将堆顶元素删除,注意,在这一步当中是不用关注初始化顺串的元素的。
  2. 然后将初始的顺串中的下一个元素放入堆中,然后调整堆,使其满足堆的性质。
    1. 如果初始的顺串被选中的元素比res数组中的最后一个元素大,那么就将这个元素放入堆中,然后调整堆;否则将这个元素先放入堆,然后与堆的最后一个元素交换,堆的大小减一,最后调整堆。
  3. 然后将堆顶元素取出,放入res数组中,然后将堆顶元素删除。
  4. 重复上述步骤2、3,直到堆为空或者初始顺串中的元素全部被替换。

看完原理,我们可以将代码分为两个部分,一个是调整堆的代码,一个是置换选择排序的代码。

代码解析

先说调整堆的代码:

void reflushHeap(int n) {int i = 1;while(2*i <= n || 2*i+1 <= n) {if(2*i <= n && 2*i+1 <= n) {if(ar[2*i] < ar[2*i+1]) {if(ar[i] > ar[2*i]) {swap(ar[i], ar[2*i]);i = 2*i;}} else {if(ar[i] > ar[2*i+1]) {swap(ar[i], ar[2*i+1]);i = 2*i+1;}}} else if(2*i <= n && 2*i+1 > n) {if(ar[i] > ar[2*i]) {swap(ar[i], ar[2*i]);i = 2*i;}	} else break;}
}

然后是置换选择排序的代码:
这代码在排除输入部分之后是这样的:

while(t--) {if(n <= 0) break;res.push_back(ar[1]);if(res.back() > in[j]) {ar[1] = in[j];swap(ar[1], ar[n]);--n;reflushHeap(n);} else {ar[1] = in[j];reflushHeap(n);}++j;
}

Code

#include <bits/stdc++.h>
#pragma GCC optimize(3,"Ofast","inline")
using namespace std;int ar[1024], in[1024];void reflushHeap(int n) {int i = 1;while(2*i <= n || 2*i+1 <= n) {if(2*i <= n && 2*i+1 <= n) {if(ar[2*i] < ar[2*i+1]) {if(ar[i] > ar[2*i]) {swap(ar[i], ar[2*i]);i = 2*i;}} else {if(ar[i] > ar[2*i+1]) {swap(ar[i], ar[2*i+1]);i = 2*i+1;}}} else if(2*i <= n && 2*i+1 > n) {if(ar[i] > ar[2*i]) {swap(ar[i], ar[2*i]);i = 2*i;}	} else break;}
}int main() {vector<int> res;ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);int m, n, t, j = 1;cin >> m >> n;res.reserve(m);for(int i = 1; i <= m; ++i) {cin >> in[i];}for(int i = 1; i <= n; ++i) {cin >> ar[i];}t = m;while(t--) {if(n <= 0) break;res.push_back(ar[1]);if(res.back() > in[j]) {ar[1] = in[j];swap(ar[1], ar[n]);--n;reflushHeap(n);} else {ar[1] = in[j];reflushHeap(n);}++j;}for(auto i: res) {cout << i << " ";}
}
http://www.yayakq.cn/news/592296/

相关文章:

  • 是做网站的怀孕后为什么不能去外包公司
  • drupal 网站开发南海网站建设价格
  • 成都哪家做网站最好软件开发工具有哪些
  • 建设行业个人信息网站阿里云网站域名绑定
  • asp.net 网站安全有人做网站吗
  • 织梦怎么用模板建站网页制作的公司企业
  • 漯河河南网站建设wordpress 主题 图
  • 个人网站设计 优帮云网站html地图怎么做
  • 成立公司怎么做网站wordpress文章图片并排
  • 那个公司可以做网站骗子会利用钓鱼网站做啥
  • 网站优化费用怎么做会计分录各种推广平台
  • 厦门海投工程建设有限公司网站广安网站建设服务
  • wordpress标题怎么廊坊seo外包公司
  • 做网站销售的话术运营哪里学的比较专业
  • 个人网站可以做淘宝客网站电线电话图怎么做
  • 资源seo网站优化排名wordpress 文件目录结构
  • 智库网站建设方案微盟商城
  • 深圳 网站建设设计wordpress中国可以上吗
  • 室内设计素材网站推荐广西柳州住房和城乡建设局网站
  • 企业 北京 响应式网站制作三合一网站开发
  • 网站的积分系统怎么做网站建设上的新闻
  • 微网站设计与开发竞赛河北百度推广
  • 设计类的网站和简介网站人群分析
  • vs网站开发视频教程网站建设选哪家公司
  • dw做购物网站网络营销方式的类型有
  • 钟祥网站建设网站建站之后需要维护吗
  • 芜湖市网站建设聊城感染最新数据
  • 设计网站界面dede旅游网站模板
  • 百度网站怎么做视频做企业推广的公司
  • 织梦网站图片代码力软框架做网站