Day3-P - Matrix POJ3685
Given a N × N matrix A, whose element in the i-th row and j-th column Aij is an number that equals i2 + 100000 × i + j2 - 100000 × j + i × j, you are to find the M-th smallest element in the matrix.
Input
The first line of input is the number of test case.
For each test case there is only one line contains two integers, N(1 ≤ N ≤ 50,000) and M(1 ≤ M ≤ N × N). There is a blank line before each test case.
Output
For each test case output the answer on a single line.
Sample Input
12 1 1 2 1 2 2 2 3 2 4 3 1 3 2 3 8 3 9 5 1 5 25 5 10
Sample Output
3
-99993
3
12
100007
-199987
-99993
100019
200013
-399969
400031
-99939 思路:观察列递增,行递减,枚举列进行二分算出第M大,然后二分枚举X是第几大,二分套二分,代码如下:
typedef long long LL; const LL INF = 0x3f3f3f3f3f3f3; LL N, M; LL calculate(LL i, LL j) {
return i * i + * i + j * j - * j + i * j;
} LL check(LL num) {
LL sum = , l, r, mid;
for (int i = ; i <= N; ++i) {
l = , r = N;
while(l <= r) {
mid = (r + l) >> ;
if(calculate(mid,i) > num) {
r = mid - ;
}
else
l = mid + ;
}
sum += r;
}
return sum;
} int main() {
LL T;
scanf("%I64d", &T);
while(T--) {
scanf("%I64d%I64d", &N, &M);
LL l = -INF, r = INF, mid;
while(l <= r) {
mid = (r + l) >> ;
if(check(mid) < M) {
l = mid + ;
}
else
r = mid - ;
}
printf("%I64d\n", l);
}
return ;
}
小结:如何寻找二分的答案,如果mid是所求答案,那么check(mid)为true,更新r的值为mid-1,之后的check都是false,从而更新l,最后l变为mid,输出mid。
比如>=的情况就是true的情况,所以一般答案都是非>=的那一侧。
补:
在二分时,注意满足的条件是满足题意还是不满足题意,New如下:(一般来说ans都在等于的那一侧,但是哪一侧是l哪一侧是r需要判断
typedef long long LL; LL N, M, mid, ans; LL calculate(LL i, LL j) {
return i * i + * i + j * j - * j + i * j;
} LL check(LL x) {
LL l, r, mid, sum = , ans;
for(int i = ; i <= N; ++i) {
l = , r = N, ans = ;
while(l <= r) {
mid = (r + l) >> ;
if(calculate(mid, i) <= x) {
ans = mid;
l = mid + ;
} else {
r = mid - ;
} }
sum += ans;
}
return sum;
} const LL INF = 0x3f3f3f3f3f3f3;
int main() {
int T;
scanf("%d", &T);
while(T--) {
scanf("%I64d%I64d", &N, &M);
//LL l = calculate(1, N), r = calculate(N, 1);
LL l = -INF, r = INF;
while(l <= r) {
mid = (r + l) >> ;
if(check(mid) < M) {
l = mid + ;
} else {
ans = mid;
r = mid - ;
}
}
printf("%I64d\n", ans);
}
return ;
}
Day3-P - Matrix POJ3685的更多相关文章
- 冬令营DAY3 T1 Matrix
题目描述 Description 生活中,我们常常用 233 表示情感.实际上,我们也会说 2333,23333,等等. 于是问题来了: 定义一种矩阵,称为 233 矩阵.矩阵的第一行依次是 2 ...
- Matrix [POJ3685] [二分套二分]
Description 有一个N阶方阵 第i行,j列的值Aij =i2 + 100000 × i + j2 - 100000 × j + i × j,需要找出这个方阵的第M小值. Input 第一行输 ...
- POJ3685 Matrix —— 二分
题目链接:http://poj.org/problem?id=3685 Matrix Time Limit: 6000MS Memory Limit: 65536K Total Submissio ...
- POJ3685 Matrix(嵌套二分)
同行元素递减,同列元素递增,采用嵌套二分的方法 #include<cstdio> #include<iostream> #include<cstdlib> #inc ...
- poj3685 Matrix
思路: 二分套二分. 矩阵在每一列上是严格递增的,可以利用这一点进行二分. 实现: #include <cstdio> #include <cmath> #include &l ...
- 2019暑期金华集训 Day3 图论
自闭集训 Day3 图论 NOI2019 D2T1 没有真正建出图来的必要,可以直接打取\(\min\)的\(tag\). 也可以把边压进堆里,然后变成一个二维清点问题(???),然后就线段树+并查集 ...
- 【POJ - 3685】Matrix(二分)
Matrix Descriptions 有一个N阶方阵 第i行,j列的值Aij =i2 + 100000 × i + j2 - 100000 × j + i × j,需要找出这个方阵的第M小值. In ...
- angular2系列教程(十一)路由嵌套、路由生命周期、matrix URL notation
今天我们要讲的是ng2的路由的第二部分,包括路由嵌套.路由生命周期等知识点. 例子 例子仍然是上节课的例子:
- Pramp mock interview (4th practice): Matrix Spiral Print
March 16, 2016 Problem statement:Given a 2D array (matrix) named M, print all items of M in a spiral ...
随机推荐
- kongdashboard
apiVersion: v1kind: Servicemetadata: name: kong-dashboard namespace: kongspec: type: NodePort po ...
- ES5-Object扩展方法
1.Object新增一个方法,Object.create();,用来以一个对象为基础创建另一个对象,新建的对象的__proto__指向基础对象 var obj = {name:'maycpou',a ...
- 吴裕雄--天生自然Numpy库学习笔记:NumPy 字节交换
大端模式:指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放 小端模式:指数据的高字节保 ...
- webstrom激活码
转自https://www.cnblogs.com/mahmud/p/11847825.html 812LFWMRSH-eyJsaWNlbnNlSWQiOiI4MTJMRldNUlNIIiwibGlj ...
- php的注释、变量、类型、常量、运算符、比较符、条件语句;
php的注释 1.// 2.# 3./* */ 变量 变量是储存信息的容器: 变量规则: 1.变量以$开头,后面跟名称>>>$sum; 2.变量必须以字母或下滑先开头,不能用数字开 ...
- apache 配置虚拟目录
#注释掉apache默认的网站目录地址 #DocumentRoot "c:/Rrogram Files/Apache/htdocs" #配置一个虚拟目录 <ifModule ...
- 操作系统OS - fork bomb(Windows)
1. Type %0|%0 2. Save the file to your desktop as anything.bat
- unique() 函数详解
简介 顾名思义,unique,独一无二的.这个函数可以对容器中的元素进行"去重". 但是需要注意,这里的"去重",并没有把重复的元素删除,只是不重复的元素放到了 ...
- Struts笔记二:栈值的内存区域及标签和拦截器
值栈和ognl表达式 1.只要是一个MVC框架,必须解决数据的存和取的问题 2.struts2利用值栈来存数据,所以值栈是一个存储数据的内存结构 1. ValueStack是一个接口,在struts ...
- idea没有import project解决办法
参考:https://blog.csdn.net/zengxiaosen/article/details/52807540