问题 A: 动态中位数问题

时间限制: 1 Sec  内存限制: 8 MB
提交: 866  解决: 102
提交 状态 算法问答

题目描述

输入一组整数a1, a2, …, an ,每输入一个整数,输出到此时为止的中位数。

中位数定义:如果数串的大小是偶数 2j,中位数是从小到大排列的第 j 个数;如果数串的大小是奇数 2j+1,中位数是从小到大排列的第 j+1 个数。

输入

一组整数,数字和数字之间以空格隔开。

输出

一组整数,数字和数字之间以空格隔开。最后一个数后面也有空格。

第 i 个输出的整数,是前 i 个输入的中位数。

样例输入

  1. -18 -2 14 -20 -6 7 2 14 11 6

样例输出

  1. -18 -18 -2 -18 -6 -6 -2 -2 2 2

提示

时间复杂度请不要超过O(nlogn)。
由于输入输出的量会比较大,因此推荐使用c语言中的scanf和printf函数来进行输入输出,能比c++中cin和cout节省许多时间。

这里本来有一行提示,但是由于老师上课不小心说漏嘴了,于是助教狠心地把它注释掉了 ;

/*在处理该问题时,堆结构也许能给你带来意想不到的帮助。*/

答案

比较尴尬,最近一忙就忘记做了,所以答案没有经过oj测试,仅供参考(但测试用例一遍过了)

思路就是维护一个mid值、最大堆(存放比mid小的值)、最小堆(存放比mid大的值),每次读入一个数,根据两边堆的大小来判断当前值,具体怎么判断见代码注释,代码中有关STL中堆的使用操作就不多数了,自行查阅。

代码在VS2017上运行,在读入输出部分可能需要更改一下,scanf_s改scanf?

  1. int main()
  2. {
  3. vector<int> heap_small; //这应该是个最大堆,存放着比mid小的元素
  4. vector<int> heap_big; //这应该是个最小堆,存放着比mid大的元素
  5. int mid =;
  6. scanf_s("%d",&mid);
  7. printf("%d ",mid);
  8. int temp = ;
  9. while (scanf_s("%d",&temp)!=EOF) {
  10. if (temp < mid) {
  11. if (heap_small.size() == heap_big.size()) {
  12. //左侧和右侧一样大,将mid放入heap_big中,temp放入heap_small中,然后从heap_small选一个最大的作为mid
  13. heap_big.emplace_back(mid);
  14. push_heap(heap_big.begin(), heap_big.end(), [](int a, int b) {return b < a; });
  15. heap_small.emplace_back(temp);
  16. push_heap(heap_small.begin(),heap_small.end());
  17. pop_heap(heap_small.begin(), heap_small.end());
  18. mid = heap_small.back();
  19. heap_small.pop_back();
  20. }else if (heap_small.size() == heap_big.size() - ) {
  21. //右侧比左侧多一个,将temp放入heap_small中,然后mid还是为中位数
  22. heap_small.emplace_back(temp);
  23. push_heap(heap_small.begin(), heap_small.end());
  24. }else {
  25. //左侧比右侧多一个的情况应该不会出现
  26. cout << "wrong" << endl;
  27. }
  28. }
  29. else {
  30. if (heap_small.size() == heap_big.size()) {
  31. //左侧和右侧一样大,将temp放入heap_big中,mid还是中位数
  32. heap_big.emplace_back(temp);
  33. push_heap(heap_big.begin(), heap_big.end(), [](int a, int b) {return b < a; });
  34. }
  35. else if (heap_small.size() == heap_big.size() - ) {
  36. //右侧比左侧多一个,将mid放入heap_small中,然后将temp放入heap_big中,然后从heap_big选一个最小的作为mid
  37. heap_small.emplace_back(mid);
  38. push_heap(heap_small.begin(), heap_small.end());
  39. heap_big.emplace_back(temp);
  40. push_heap(heap_big.begin(), heap_big.end(), [](int a, int b) {return b < a; });
  41. pop_heap(heap_big.begin(), heap_big.end(), [](int a, int b) {return b < a; });
  42. mid = heap_big.back();
  43. heap_big.pop_back();
  44. }
  45. else {
  46. //左侧比右侧多一个的情况应该不会出现
  47. cout << "wrong" << endl;
  48. }
  49. }
  50. printf("%d ",mid);
  51. }
  52. return ;
  53. }

问题 B: 非完美二叉树的高度与直径

时间限制: 2 Sec  内存限制: 3 MB
提交: 249  解决: 95
提交 状态 算法问答

题目描述

记T为一棵二叉树,树中共有n个节点。

定义根节点的深度为0,其余节点的深度为其父节点的深度加1。T的高度定义为其叶节点深度的最大值。

定义树中任意两点a和b之间的距离为其间最短简单路径的长度。T的直径定义为T中所有点对间距离的最大值。

输入一棵二叉树T,请计算它的高度和直径。

输入

输入共三行。

第一行输入n的值,表示树中结点的总个数。

第二行为树的前序遍历表示,每个节点之间用空格隔开。

第三行为树的中序遍历表示,每个节点之间也用空格隔开。

输出

输出共三行。
第一行需要大家输出一行字符串,它是“我已阅读关于抄袭的说明”的英文翻译,即:"I have read the rules about plagiarism punishment"。输出此行的提交我们将认为已经完全阅读并了解了“关于抄袭的说明”公告并同意关于抄袭的惩罚措施。
第二行输出树的高度。
第三行输出树的直径。

样例输入

  1. 10
  2. 0 1 9 3 8 4 2 7 5 6
  3. 3 9 8 1 2 4 0 5 7 6

样例输出

  1. I have read the rules about plagiarism punishment
  2. 3
  3. 5

提示

分治算法可以在O(n)的时间内完成相应的计算。

答案

没法提交了,懒得写了,网上答案挺多的

南大算法设计与分析课程OJ答案代码(3)的更多相关文章

  1. 南大算法设计与分析课程OJ答案代码(5)--割点与桥和任务调度问题

    问题 A: 割点与桥 时间限制: 1 Sec  内存限制: 5 MB提交: 475  解决: 34提交 状态 算法问答 题目描述 给出一个无向连通图,找到所有的割点和桥 输入 第一行:点的个数,如果点 ...

  2. 南大算法设计与分析课程OJ答案代码(4)--变位词、三数之和

    问题 A: 变位词 时间限制: 2 Sec  内存限制: 10 MB提交: 322  解决: 59提交 状态 算法问答 题目描述 请大家在做oj题之前,仔细阅读关于抄袭的说明http://www.bi ...

  3. 南大算法设计与分析课程OJ答案代码(2)最大子序列和问题、所有的逆序对

    问题 A: 最大子序列和问题 时间限制: 1 Sec  内存限制: 4 MB提交: 184  解决: 66提交 状态 算法问答 题目描述 给定一整数序列 a1, a2, …, an,求 a1~an 的 ...

  4. 南大算法设计与分析课程OJ答案代码(1)中位数附近2k+1个数、任意两数之和是否等于给定数

    问题1 用来测试的,就不说了 问题2:中位数附近2k+1个数 给出一串整型数 a1,a2,...,an 以及一个较小的常数 k,找出这串数的中位数 m 和最接近 m 的小于等于 m 的 k 个数,以及 ...

  5. 南大算法设计与分析课程复习笔记(1) L1 - Model of computation

    一.计算模型 1.1 定义: 我们在思考和处理算法的时候是机器无关.实现语言无关的.所有的算法运行在一种“抽象的机器”之上,这就是计算模型. 1.2 种类 图灵机是最有名的计算模型,本课使用更简单更合 ...

  6. 南大算法设计与分析课程复习笔记(4)L4 - QuickSort

    一.快速排序 算法导论上关于快速排序有两种写法 第一种,从头到尾遍历,不断将小于基准元素的项移到前面.代码很简介,只需要维护一个交换位置,表示小于基准元素的末尾位置加一 我们看算法导论上的一个例子: ...

  7. 南大算法设计与分析课程复习笔记(3)L3 - Recursion

    一.递归方程 按照分治的思想,可以将一个递归的复杂度写成递归方程 一.解递归方程--猜然后证明 该方法又称为代入法,步骤如下: 1.猜解的形式 2.数学归纳法证明正确 例子: 我们假设有如下递归式: ...

  8. 南大算法设计与分析课程复习笔记(2)L2 - Asymptotics

    一.几种比较复杂度的符号 数据结构有描述,相关严格数学定义也不想说了,就这么过了吧. 二.最大子数组的几种解决方法 从最复杂的暴力解法过渡到最简单的动态规划 解析和代码见这里:http://www.c ...

  9. 算法设计与分析 - AC 题目 - 第 5 弹(重复第 2 弹)

    PTA-算法设计与分析-AC原题 - 最大子列和问题 (20分) 给定K个整数组成的序列{ N1, N2, ..., NK },“连续子列”被定义为{ Ni, Ni+, ..., Nj },其中 ≤i ...

随机推荐

  1. 重装win10+ubuntu 双系统 UEFI启动模式

    有较强的时效性!!先看一眼日期是否太古老! 任务 卸载双系统中的Ubuntu14,安装Ubuntu16 环境 操作系统: Win10 + Ubuntu14双系统 硬盘: 固态硬盘 + 机械硬盘,电脑的 ...

  2. 文本超过控件长度自动显示省略号的css

    overflow: hidden; white-space: nowrap; text-overflow: ellipsis;

  3. 【pycharm】pycharm修改文件名快捷键

    shift+F6 修改文件名 --------------------------------------------------

  4. window7 32位部署django

    window7 32位安装环境,所有的软件都用32位的,如果你想要用64位的软件需要操作系统和下面的相关软件都换成64位,我是在虚拟机上装了win7 32版做的测试. 软件下载地址: python2. ...

  5. mysql客户端连不上数据库

    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION; flush privileges ...

  6. wechat.php

    <?php/***Author @zhongbo * 步骤说明* 1,微信服务器返回一个会话ID* 2.通过会话ID获得二维码* 3.轮询手机端是否已经扫描二维码并确认在Web端登录* 4.访问 ...

  7. job定时任务

    1,定时任务依赖的执行类 2.引入job 3.执行时间 4.管理job

  8. PaaS平台的尴尬与变革

    当今时代只要提到云计算这个词语,一定会提到云计算分为IaaS.PaaS.SaaS 这三个层面,现阶段云环境中IaaS和SaaS都实现了商品化.但是,PaaS作为云计算的服务模式之一,既不像IaaS那样 ...

  9. 看我是如何利用升级系统一键GetShell

    i春秋作家:小猪 原文来自:看我是如何利用升级系统一键GetShell 漏洞名称:看我是如何利用升级系统一键GetShell 程序下载地址:https://pan.baidu.com/s/1VdoPL ...

  10. 技术干货:实时视频直播首屏耗时400ms内的优化实践

    本文由“逆流的鱼yuiop”原创分享于“何俊林”公众号,感谢作者的无私分享. 1.引言 直播行业的竞争越来越激烈,进过2018年这波洗牌后,已经度过了蛮荒暴力期,剩下的都是在不断追求体验.最近正好在做 ...