noip模拟赛 第K小数
【问题描述】
有两个正整数数列,元素个数分别为N和M。从两个数列中分别任取一个数
相乘,这样一共可以得到N*M个数,询问这N*M个数中第K小数是多少。
【输入格式】
输入文件名为number.in。
输入文件包含三行。
第一行为三个正整数N,M和K。
第二行为N个正整数,表示第一个数列。
第三行为M个正整数,表述第二个数列。
【输出格式】
输出文件名为number.out。
输出文件包含一行,一个正整数表示第K小数。
【输入输出样例1】
| number.in | number.out |
| 2 3 4 1 2 2 1 3 |
3 |
【输入输出样例2】
| number.in | number.out |
| 5 5 18 7 2 3 5 8 3 1 3 2 5 |
16 |
【数据规模与约定】
| 样例点编号 | N | M | K | 元素大小(≤) |
| 1 | 20 | 20 | 150 | 10^4 |
| 2 | 50 | 50 | 2000 | 10^4 |
| 3 | 100 | 80 | 5000 | 10^9 |
| 4 | 200 | 200 | 26000 | 10^9 |
| 5 | 10000 | 10000 | 50050000 | 10^4 |
| 6 | 1000 | 20000 | 9500000 | 10^4 |
| 7 | 1000 | 20000 | 10000500 | 10^9 |
| 8 | 2000 | 20000 | 190000 | 10^9 |
| 9 | 2000 | 20000 | 199000 | 10^9 |
| 10 | 20000 | 20000 | 210005000 | 10^4 |
| 11 | 20000 | 20000 | 210000 | 10^5 |
| 12 | 20000 | 20000 | 200000 | 10^9 |
| 13 | 20000 | 20000 | 220000500 | 10^5 |
| 14 | 20000 | 20000 | 199000500 | 10^9 |
| 15 | 200000 | 200000 | 180000 | 10^4 |
| 16 | 200000 | 200000 | 200000 | 10^9 |
| 17 | 2000 | 200000 | 100001500 | 10^9 |
| 18 | 200000 | 180000 | 19550000000 | 10^5 |
| 19 | 200000 | 200000 | 19900010000 | 10^9 |
| 20 | 200000 | 200000 | 20000010000 | 10^9 |
分析:非常经典的一道题,要求第K小/大之类的显然可以二分,看比它小的数有多少个,统计个数主要还是乘法原理,将两个序列排序,然后移动两个指针,一个从小到大,一个从大到小,因为满足单调性,一个乘法就解决了.
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm> using namespace std; typedef long long ll; ll n, m, k, a[], b[], max1, max2, ans, cnt1, cnt2; ll check(ll x)
{
ll cur1 = , cur2 = m, sum = ;
while (cur2 > && cur1 <= n)
{
while (a[cur1] * b[cur2] > x)
cur2--;
sum += cur2;
cur1++;
}
return sum;
} int main()
{
scanf("%lld%lld%lld", &n, &m, &k);
for (ll i = ; i <= n; i++)
{
scanf("%lld", &a[i]);
max1 = max(max1, a[i]);
}
for (ll i = ; i <= m; i++)
{
scanf("%lld", &b[i]);
max2 = max(max2, b[i]);
}
sort(a + , a + + n);
sort(b + , b + + m);
ll l = , r = max1 * max2;
while (l <= r)
{
ll mid = (l + r) >> ;
if (check(mid) >= k)
{
ans = mid;
r = mid - ;
}
else
l = mid + ;
}
printf("%lld\n", ans); return ;
}
noip模拟赛 第K小数的更多相关文章
- noip模拟赛 第k大区间
[问题描述] 定义一个长度为奇数的区间的值为其所包含的的元素的中位数. 现给出n个数,求将所有长度为奇数的区间的值排序后,第K大的值为多少. [输入] 输入文件名为kth.in. 第一行两个数n和k ...
- 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程
数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...
- 2016-06-19 NOIP模拟赛
2016-06-19 NOIP模拟赛 by coolyangzc 共3道题目,时间3小时 题目名 高级打字机 不等数列 经营与开发 源文件 type.cpp/c/pas num.cpp/c ...
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...
- CH Round #58 - OrzCC杯noip模拟赛day2
A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...
- CH Round #52 - Thinking Bear #1 (NOIP模拟赛)
A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...
- CH Round #49 - Streaming #4 (NOIP模拟赛Day2)
A.二叉树的的根 题目:http://www.contesthunter.org/contest/CH%20Round%20%2349%20-%20Streaming%20%234%20(NOIP 模 ...
随机推荐
- bzoj 1603: [Usaco2008 Oct]打谷机【瞎搞】
一棵树,碰到改变转向的边就异或一下,从1dfs一遍 #include<iostream> #include<cstdio> using namespace std; const ...
- bzoj 1633: [Usaco2007 Feb]The Cow Lexicon 牛的词典【dp】
预处理出g[i][j]表示原串第i个匹配第j个单词需要去掉几个字母(匹配不上为-1) 设f[i]为i及之后满足条件要去掉的最少字母 倒着dp! f[i]初始为f[i+1]+1,转移方程为f[i]=mi ...
- hdu1512 Monkey King(并查集,左偏堆)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1512 题目大意:有n个猴子,一开始每个猴子只认识自己.每个猴子有一个力量值,力量值越大表示这个猴子打架 ...
- P3990 [SHOI2013]超级跳马
传送门 首先不难设\(f[i][j]\)表示跳到\((i,j)\)的方案数,那么不难得到如下转移 \[f[i][j]=\sum\limits_{k=1}^{\frac n2}f[i-2k+1][j-1 ...
- QRCoder生成二维码
现在二维码支付越来越流行,二维码使用的地方越来越多,项目中也需要一个二维码生成工具,QRCoder是一个简单的生成二维码的库,用C#.NET编写,他是开源的MIT-license. 二维码简介 二维条 ...
- java 序列化和反序列化数据
使用ObjectOutputStream 序列号原始数据和对象数据,使用ObjectInputStream 反序列化 使用字节存储数据,可以将序列化的数据存储到硬盘上,或输出到网络上 package ...
- 微信小程序一些常见的坑
1.小程序都报wxss编译错误 解决方法: 在控制台输入openVendor() ,清除里面的wcsc wcsc.exe 然后重启工具 2.微信小程序wx:for警告 Now you can prov ...
- POJ_3278_Catch That Cow
Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 54911 Accepted: 17176 ...
- Linux文件排序和FASTA文件操作
文件排序 seq: 产生一系列的数字; man seq查看其具体使用.我们这使用seq产生下游分析所用到的输入文件. # 产生从1到10的数,步长为1 $ seq 1 10 1 2 3 4 5 6 7 ...
- Java基础(六)--枚举Enum
枚举: 刚开始项目中没怎么用过,只知道能够实现作为项目中类似定义Constant的功能,然后知道枚举实现的单例模式几乎是最优雅的,所以, 想要深入完整的了解一下 1.基本特性: Enum.values ...