poj2785 简单二分
| Time Limit: 15000MS | Memory Limit: 228000K | |
| Total Submissions: 19243 | Accepted: 5744 | |
| Case Time Limit: 5000MS | ||
Description
Input
Output
Sample Input
6
-45 22 42 -16
-41 -27 56 30
-36 53 -37 77
-36 30 -75 -46
26 -38 -10 62
-32 -54 -6 45
Sample Output
5
Hint
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <queue>
#include <stack>
#define mem(a) memset(a,0,sizeof(a))
using namespace std;
const int inf=0xffffff;
const int maxn=4000+10;
int a[maxn],b[maxn],c[maxn],d[maxn];
int f1[maxn*maxn],f2[maxn*maxn];
int main()
{
int n;
while(scanf("%d",&n)!=EOF)
{
int cut=0;
for(int i=0;i<n;i++)
scanf("%d%d%d%d",&a[i],&b[i],&c[i],&d[i]);
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
f1[i*n+j]=a[i]+b[j];
f2[i*n+j]=c[i]+d[j];
}
}
sort(f2,f2+n*n);
for(int i=0;i<n*n;i++)
{
int low=0,high=n*n-1;
while(low<=high)
{
int mid=(low+high)/2;
if(f2[mid]==-f1[i])
{
cut++;
for(int j=mid-1;j>=0;j--)
{
if(f2[j]!=-f1[i]) break;
cut++;
}
for(int j=mid+1;j<n*n;j++)
{
if(f2[j]!=-f1[i]) break;
cut++;
}
break;
}
else if(f2[mid]<-f1[i]) low=mid+1;
else high=mid-1;
}
}
cout<<cut<<endl;
}
return 0;
}
poj2785 简单二分的更多相关文章
- HDU2199,HDU2899,HDU1969,HDU2141--(简单二分)
		
二分是一种很有效的减少时间开销的策略, 我觉得单列出二分专题有些不太合理, 二分应该作为一中优化方法来考虑 这几道题都是简单的使用了二分方法优化, 二分虽然看似很简单, 但一不注意就会犯错. 在写二分 ...
 - 一些简单二分题,简单的hash,H(i),字符串题
		
说在前面: 题是乱七八糟的. 几个二分的题. (但是我的做法不一定是二分,有些裸暴力. 1. Equations HDU - 1496 输入a,b,c,d问你这个方程有多少解.a*x1^2+b*x2^ ...
 - hdu-4185.loiol_skimming(简单二分匹配模型)
		
/************************************************************************* > File Name: hdu-4185. ...
 - POJ2239简单二分匹配
		
题意: 一周有7天,每天可以上12节课,现在给你每科课的上课时间,问你一周最多可以上几科课,一科课只要上一节就行了. 思路: 简单题目,直接二分就行了,好久没写二分匹配了,练习 ...
 - CF 706B   简单二分,水
		
1.CF 706B Interesting drink 2.链接:http://codeforces.com/problemset/problem/706/B 3.总结:二分 题意:给出n个数,再给 ...
 - poj 3273 Monthly  Expence 简单二分
		
/** 大意: 有连续的n天,每一天有一定的花费,将其分成m份,每一份占一天或者连续的几天,求这m份中的最大值 思路: 二分其最大上限,看在此最大上线,能分成多少份,若大于m份,说明上限过小,需要扩大 ...
 - Codeforces 846D Monitor(简单二分+二维BIT)
		
D. Monitor time limit per test 2 seconds memory limit per test 256 megabytes input standard input ou ...
 - SPOJ-COLONY - Linearian Colony!简单二分思想
		
COLONY - Linearian Colony 一道很水的题却坑我两天!在CF上做过类似的题,用递归可以找到答案,但感觉不会这么麻烦,于是看看有没有什么规律,对Y分奇偶貌似可以找到规律,但WA了三 ...
 - 二维数组中的查找 - Java版 -简单二分查找 -<<剑指Offer>> -水题
		
如题 (总结) -认真读题, 还WA了一次, https://www.nowcoder.com/practice/abc3fe2ce8e146608e868a70efebf62e?tpId=13&am ...
 
随机推荐
- UVA10090 数论基础 exgcd
			
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
 - shell的string operator
			
${varname:-word} 如果varname存在并且不为nil,那么返回varname的值,否则返回word.这个常用来在varname未定义时返回默认值 ${varname:=word} 如 ...
 - C#Mysql数据库爆破源码
			
声明: 代码仅供学习参考使用!开启了一个子线程,进行爆破! 速度不是很快,代码不是很规范,希望大牛不要喷我! c#控制台程序,需要引用MySql.Data.dll 默认用户名: root密码字典: p ...
 - Jquery简略API使用
			
都是个人随手笔记,既然开通了博客园就分享给大家.谨做为参考,具体大家自己测试以及使用 ★ $() ★ JQ的一个万能获取对象的函数(获取跟CSS获取元素是一样的)$(function(){}); 替代 ...
 - Debian/Ubuntu 安装bcm43142无线网卡驱动
			
Drivers for Broadcom BCM43142 wireless card of Ubuntu/Debian 64-bit Linux 1.Check the wireless card ...
 - android开发
			
从某种意义上讲,垃圾收集机制把程序员从“内存管理噩梦”中解放出来,而 Android 的进程生命周期管理机制把用户从“任务管理噩梦”中解放出来.我见过一些 Nokia S60 用户和 Windows ...
 - Underscore.js(1.7.0) 中文文档 Underscore.js 入门
			
原文地址:http://www.css88.com/doc/underscore/ Underscore.js 入门 http://www.tuicool.com/articles/jQ3IfeR
 - Java Web----Java Web的数据库操作(一)
			
Java Web的数据库操作 一.JDBC技术 1.JDBC简介 JDBC是Java程序与数据库系统通信的标准API,它定义在JDK的API中,通过JDBC技术,Java程序可以非常方便地与各种数据库 ...
 - C语言中所有变量和常量所使用的内存总结
			
(1)相同点:三种获取内存的方法,都可以给程序提供可用内存,都可以用来定义变量给程序用.(2)不同点:栈内存对应C中的普通局部变量(别的变量还用不了栈,而且栈是自动的,由编译器和运行时环境共同来提供服 ...
 - 传智播客 Html基础知识学习笔记2
			
一.<select>标签 用来创建类似于WinForm中的ComboBox(下拉列表)或者LisBox 如果size大于1就是LisBox,否则就是ComboBox; <select ...