博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PAT A1029
阅读量:6884 次
发布时间:2019-06-27

本文共 1152 字,大约阅读时间需要 3 分钟。

clipboard.png

起先自己想尝试性的直接排序找中位数,内存直接超限;

其实这道题可以采用归并排序的思路来做:

但是示例依旧白给。。。不过还是展现了一种思想,代码如下:

#include
#include
#include
#include
#include
using namespace std;using std::vector;const int maxn=1000010;const int INF=0x7fffffff;int a[maxn];int b[maxn];int main(){ int n,m; scanf("%d",&n); int index=0; for(int i=0;i

网上给出了一种示例,能够完全AC;

#include 
using namespace std;int k[200005];int main(){ int n, m, temp, count = 0; cin >> n; for (int i = 1; i <= n; i++) scanf("%d", &k[i]); k[n + 1] = 0x7fffffff; cin >> m; int midpos = (n + m + 1) / 2, i = 1; for (int j = 1; j <= m; j++) { scanf("%d", &temp); while (k[i] < temp) { count++; if (count == midpos) cout << k[i]; i++; } count++; if (count == midpos) cout << temp; } while (i <= n) { count++; if (count == midpos) cout << k[i]; i++; } return 0;}

具体的思路就是,输入第一个序列;

在输入第二个序列的时候进行判断,主要的判断逻辑为:
如果输入的值小于第一个序列的相应值,cout++,跳过该值;
如果大于相应值,进行向后判断,cout计算增加的值;
如果发现途中cout的值等于中点值,直接进行输出,程序停止;

转载地址:http://wrnbl.baihongyu.com/

你可能感兴趣的文章
[傅里叶变换及其应用学习笔记] 二十三. 线性时不变系统的基本定义
查看>>
[New Portal]Windows Azure Virtual Machine (3) 在VM上挂载磁盘
查看>>
字体随着ProgressBar的加载而滚动
查看>>
Handler 机制再了解
查看>>
如果你是前端工程师,把你的网站或者你知道的网站加进来吧
查看>>
阿里云产品头条(2017年12月刊)
查看>>
探究SQL添加非聚集索引,性能提高几十倍之谜
查看>>
Java 如何不使用 volatile 和锁实现共享变量的同步操作
查看>>
Java架构-Java代码规范那些事
查看>>
容器监控实践—PromQL查询解析
查看>>
追踪解析 Disruptor 源码
查看>>
【剑指offer】让抽象问题具体化
查看>>
聊聊flink的AbstractNonHaServices
查看>>
搭建一个通用的脚手架
查看>>
PAT A1071
查看>>
【笔记】重学前端-winter
查看>>
windows下重装xampp并做mysql数据迁移的步骤
查看>>
Java日志组件间关系
查看>>
聊聊前端国际化文案该如何处理
查看>>
JS难点之hoist
查看>>