1105 第K大的数
第1行:2个数N和K,中间用空格分隔。N为数组的长度,K对应第K大的数。(2 <= N <= 50000,1 <= K <= 10^9)
第2 - N + 1行:每行2个数,分别是A[i]和B[i]。(1 <= A[i],B[i] <= 10^9)
输出第K大的数。
3 2
1 2
2 3
3 4
9
思路:二分,先排序,首先二分答案,答案的范围在ans[0]*bns[0]---ans[n-1]*bns[n-1]之间,然后二分统计这个答案的前面是否有大于等于k个比他大的,符合的话并且二分检查这个答案是否存在。
1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<string.h>
5 #include<queue>
6 #include<math.h>
7 #include<set>
8 #include<vector>
9 #include<string.h>
10 using namespace std;
11 typedef long long LL;
12 typedef struct node {
13 LL x;
14 LL y;
15 } ss;
16 LL ans[60000];
17 LL bns[60000];
18 bool check(LL n,LL N,LL M) {
19 int i,j;
20 LL cnt = 0;
21 for(i = 0; i < N; i++) {
22 int l = 0;
23 int r =N;
24 int id = -1;
25 while(l<=r) {
26 int mid = (l+r)/2;
27 if(bns[mid]*ans[i]>=n) {
28 id = mid;
29 r = mid - 1;
30 } else l= mid + 1;
31 }
32 if(id!=-1) {
33 if(n==12)printf("%d\n",id);
34 cnt += N-id;
35 }
36 }
37 if(cnt>=M)return true;
38 return false ;
39 }
40 bool er(int n,int m,int ask);
41 bool test(LL mid,LL N,LL M);
42 int main(void) {
43 LL N,M;
44 scanf("%lld %lld",&N,&M);
45 int i,j;
46 for(i = 0; i < N; i++) {
47 scanf("%lld %lld",&ans[i],&bns[i]);
48 }
49 sort(ans,ans+N);
50 sort(bns,bns+N);
51 LL ak = ans[0]*bns[0];
52 LL bk = ans[N-1]*bns[N-1];
53 LL all = -1;//printf("%lld %lld\n",ak,bk);
54 while(ak<=bk) {
55 LL mid = (ak+bk)/2;
56 if(check(mid,N,M)) {
57 if(test(mid,N,M))
58 all = max(mid,all);
59 ak = mid + 1;
60 } else bk = mid-1;
61 }
62 printf("%lld\n",all);
63 return 0;
64 }
65 bool test(LL mid,LL N,LL M) {
66 int i,j;
67 LL kk;
68 for(i = 0; i < N; i++) {
69 if(mid%ans[i]==0) {
70 if(er(0,N,mid/ans[i]))
71 return true;
72 }
73 }
74 }
75 bool er(int n,int m,int ask) {
76 if(n>m)return false;
77 int mid = (n+m)/2;
78 if(bns[mid]==ask) {
79 return true;
80 } else if(bns[mid]>ask) {
81 return er(n,mid-1,ask);
82 } else return er(mid+1,m,ask);
83 }
复杂度N*log(N);
1105 第K大的数的更多相关文章
- 51 nod 1105 第K大的数
1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...
- 1105 第K大的数(二分)
1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * B[0],A[0 ...
- 51nod 1105 第K大的数 【双重二分/二分套二分/两数组任意乘积后第K大数】
1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...
- 51NOD 1105 第K大的数
数组A和数组B,里面都有n个整数. 数组C共有n^2个整数,分别是: A[0] * B[0],A[0] * B[1] ...... A[0] * B[n-1] A[1] * B[0],A[1] * B ...
- AC日记——第K大的数 51nod 1105
1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...
- 51nod 1105:第K大的数
1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...
- [51NOD1105]第k大的数(二分答案)
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1105 先排序,二分上下界分别是最小的两个数和最大的两个数的乘积 ...
- POJ 2985 The k-th Largest Group(树状数组 并查集/查找第k大的数)
传送门 The k-th Largest Group Time Limit: 2000MS Memory Limit: 131072K Total Submissions: 8690 Acce ...
- 51nod p1175 区间中第K大的数
1175 区间中第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 160 难度:6级算法题 一个长度为N的整数序列,编号0 - N - 1.进行Q次查询,查询编号i至j的所有 ...
随机推荐
- Python文件复制shutil模块
Python中shutil模块主要用于文件操作,如复制,属性判断等 1.copyfileobj,拷贝文件内容,将文件句柄赋给该方法 def copyfileobj(src, dst, length=1 ...
- 简易kmeans-c++版本
typedef double dtype; 主要接口: void Kmeans(const vector<vector<dtype> > &d,int k,string ...
- 标准非STL容器 : bitset
1. 概念 什么是"标准非STL容器"?标准非STL容器是指"可以认为它们是容器,但是他们并不满足STL容器的所有要求".前文提到的容器适配器stack.que ...
- springcloud - alibaba - 2 - 集成Feign - 更新完成
1.依赖 依赖管理 <parent> <artifactId>spring-boot-parent</artifactId> <groupId>org. ...
- 日常Javaweb 2021/11/19
Javaweb Dao层: //连接数据库,实现增查功能 package dao; import java.sql.Connection; import java.sql.DriverManager; ...
- 学习java 7.20
学习内容: Stream流 Stream流的生成方式 中间操作方法 终结操作方法 Stream流的收集操作 类加载 类加载器的作用 将.class文件加载到内存中,并为之生成对应的java.lang. ...
- k8s配置中心-configmap,Secret密码
目录 k8s配置中心-configmap,Secret 创建ConfigMap 使用ConfigMap subPath参数 Secret 官方文档 编写secret清单 使用secret 在 Pod ...
- 编程之美Q1
题目 和数书页有点类似,就直接数吧 #include<iostream> using namespace std; class q1 { public: size_t func(size_ ...
- Redis的持久化机制:RDB和AOF
什么是Redis持久化? Redis作为一个键值对内存数据库(NoSQL),数据都存储在内存当中,在处理客户端请求时,所有操作都在内存当中进行,如下所示: 这样做有什么问题呢? 其实,只要稍微有点计算 ...
- javaAPI2
---------------------------------------------------------------------------------------------------- ...