hdu 4631 Sad Love Story
http://acm.hdu.edu.cn/showproblem.php?pid=4631
没想到这道题需要用“平均时间复杂度” 计算 一直没有想到解法 因为不符考虑了最坏情况的理念
方法一:
每加一个点 就找x值和它接近的 有可能更新最小距离的点进行判断更新 运行的相当的快 无语
方法二:
每求出所有点的最近点对 假如说是p[i],p[j](i<j) 那么在j之后加上的点不影响最小距离
递归j前面的所有点就可以了
由于自己的 求最近点对算法 写的相当烂 所有跑的相当慢,勉强过
代码1和代码2:
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<string>
#include<cstring>
#include<cmath>
#include<set>
#include<vector>
using namespace std; typedef long long ll;
typedef pair<double,double>ppd;
const double PI = acos(-1.);
const double eps = (1e-9);
const int N=1000010;
vector<int>vt[N];
int main()
{
//freopen("data.in","r",stdin);
int T;
scanf("%d",&T);
while(T--)
{
for(int i=0;i<N;++i)
vt[i].clear();
int n;
scanf("%d",&n);
int A1,B1,C1,A2,B2,C2;
cin>>A1>>B1>>C1;
cin>>A2>>B2>>C2;
int x=0,y=0;
ll ans=0;
ll tmp=(ll)(1e13);
for(int i=1;i<=n;++i)
{
x=((ll)A1*x+B1)%C1;
y=((ll)A2*y+B2)%C2;
for(int i=0;x+i<=1000000;++i)
{
ll x1=(ll)i*i;
if(x1>=tmp)
break;
for(unsigned int j=0;j<vt[x+i].size();++j)
tmp=min(tmp,x1+(ll)(y-vt[x+i][j])*(y-vt[x+i][j]));
}
for(int i=-1;x+i>=0;--i)
{
ll x1=(ll)i*i;
if(x1>=tmp)
break;
for(unsigned int j=0;j<vt[x+i].size();++j)
tmp=min(tmp,x1+(ll)(y-vt[x+i][j])*(y-vt[x+i][j]));
}
vt[x].push_back(y);
if(tmp!=(ll)(1e13))
ans+=tmp;
}
cout<<ans<<endl;
}
return 0;
} #include<iostream>
#include<cstdio>
#include<algorithm>
#include<string>
#include<cstring>
#include<cmath>
#include<set>
#include<vector>
using namespace std; typedef long long ll;
typedef pair<int,int>pp;
const double PI = acos(-1.);
const double eps = (1e-9);
const int N=1000010;
pp p[N];
struct node
{
int x,y;
int index;
}a[N],b[N];
ll dist(const node &a,const node &b)
{
return (ll)(a.x-b.x)*(a.x-b.x)
+(ll)(a.y-b.y)*(a.y-b.y);
}
bool cmpx(const node &a,const node &b)
{
return a.x<b.x;
}
bool cmpy(const node &a,const node &b)
{
return a.y<b.y;
}
ll dfs(int l,int r,int &k)
{
if(r-l==1)
{k=max(a[l].index,a[r].index);return dist(a[l],a[r]);}
int m=(l+r)>>1;
int k1,k2;
ll d;
ll d1=dfs(l,m,k1);
ll d2=dfs(m,r,k2);
if(d1<d2) {d=d1;k=k1;}
else {d=d2;k=k2;}
int ln=0,M=(int)(sqrt(1.0*d));
for(int i=m+1;i<=r&&a[i].x-a[m].x<=M;++i)
{b[ln]=a[i];++ln;}
for(int i=m-1;i>=l&&a[m].x-a[i].x<=M;--i)
{b[ln]=a[i];++ln;}
sort(b,b+ln,cmpy);
for(int i=0;i<ln;++i)
for(int j=1;j<=7&&i+j<ln;++j)
if(dist(b[i],b[i+j])<d)
{d=dist(b[i],b[i+j]);k=max(b[i].index,b[i+j].index);}
return d;
}
ll solve(int n)
{
ll ans=0;
int r=n;
while(r>=2)
{
for(int i=1;i<=r;++i)
{a[i].x=p[i].first;a[i].y=p[i].second;a[i].index=i;}
sort(a+1,a+r+1,cmpx);
int k;
ll tmp=dfs(1,r,k);
ans+=tmp*(r-k+1);
r=k-1;
}
return ans;
}
int main()
{
//freopen("data.in","r",stdin);
int T;
scanf("%d",&T);
while(T--)
{
int n;
scanf("%d",&n);
int A1,B1,C1,A2,B2,C2;
scanf("%d %d %d",&A1,&B1,&C1);
scanf("%d %d %d",&A2,&B2,&C2);
p[0].first=0,p[0].second=0;
for(int i=1;i<=n;++i)
{
p[i].first=((ll)A1*p[i-1].first+B1)%C1;
p[i].second=((ll)A2*p[i-1].second+B2)%C2;
}
cout<<solve(n)<<endl;
}
return 0;
}
hdu 4631 Sad Love Story的更多相关文章
- HDU 4631 Sad Love Story 平面内最近点对
http://acm.hdu.edu.cn/showproblem.php?pid=4631 题意: 在平面内依次加点,求每次加点后最近点对距离平方的和 因为是找平面最近点对...所以加点以后这个最短 ...
- HDU 4631 Sad Love Story (2013多校3 1011题 平面最近点对+爆搞)
Sad Love Story Time Limit: 40000/20000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others ...
- hdu 4631(最近点对,容器)
点击打开链接 题意: 给你一个平面,每次加入一个点,当点数>=2时,求最近点对距离的平方,最后输出所有的平方和. 给你a,b,c x[0]=0;x[i]=(x[i-1]*a+b)%c 如果按照平 ...
- 【 2013 Multi-University Training Contest 3 】
HDU 4622 Reincarnation 枚举字符串的起点,构造后缀自动机,每次插入一个字符,就能统计得到当前不同字串的个数,预处理出所有的询问. #include<cstdio> # ...
- hdu 4631Sad Love Story<计算几何>
链接:http://acm.hdu.edu.cn/showproblem.php?pid=4631 题意:依次给你n个点,每次求出当前点中的最近点对,输出所有最近点对的和: 思路:按照x排序,然后用s ...
- hdu 1753 大明A+B
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1753 容易出错的事例: 0.1 0.2 1.88 22.22 1 0.01 大概出错的几个点,做久了思维根 ...
- HDU 5828 Rikka with Sequence (线段树)
Rikka with Sequence 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5828 Description As we know, Rik ...
- HDU-4631 Sad Love Story 平面最近点对
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4631 数据是随机的,没有极端数据,所以可以分段考虑,最小值是一个单调不增的函数,然后每次分治算平面最近 ...
- HDU 4931 Happy Three Friends(水)
HDU 4931 Happy Three Friends 题目链接 题意:6个数字,一个取两个,妹子取三个,问最后谁会赢 思路:排个序,推断前两个和3 - 5个的和谁更大就可以 代码: #includ ...
随机推荐
- [转载] 根据多年经验整理的《互联网MySQL开发规范》
原文: http://weibo.com/p/2304181380b3f180102vsg5 根据多年经验整理的<互联网MySQL开发规范> 写在前面:无规矩不成方圆.对于刚加入互联网的朋 ...
- cheat-linux命令行实用助记工具
cheat究竟用来干嘛? 我们虽然能够使用man和--help来帮助我们查看命令使用方式,但是很多工程师都觉得,他们显然还不够man! 看看cheat是怎么man的 当我敲下cheat tar的时候, ...
- 关于php的一些小知识
浏览目录: 一.PHP的背景和优势: 二.PHP原理简介: 三.PHP运行环境配置: 四.编写简单的PHP代码以及测试. 一.PHP的背景和优势 1.1 什么是PHP? PHP是能让你生成动态网页 ...
- TCP/IP,Http,Socket,XMPP的区别
大学学习网络基础的时候老师讲过,网络由下往上分为物理层.数据链路层.网络层.传输层.会话层.表示层和应用层.通过初步的了解,我知道IP协议对应于网络层,TCP协议对应于传输层,而HTTP协议对应于应用 ...
- iOS开发之 Xcode 一个工程 Project 添加多个 target
http://www.360doc.com/content/14/1203/11/19119980_430056974.shtml# 根据项目需求,同一个工程有多个版本,每个版本只有细微的不同.所以, ...
- Android开发面试经——6.常见面试官提问Android题②(更新中...)
版权声明:本文为寻梦-finddreams原创文章,请关注:http://blog.csdn.net/finddreams 关注finddreams博客:http://blog.csdn.net/fi ...
- Nginx安装(zhuan)
http://www.nginx.cn/install ************************ nginx可以使用各平台的默认包来安装,本文是介绍使用源码编译安装,包括具体的编译参数信息. ...
- Jquery_改变背景颜色
$(this).addClass("car_check").siblings().removeClass("car_check");//设置全部车辆为选中状态
- Asp.Net_Web身份验证
百度一下”asp.net身份认证“,你会得到很多相关的资料,这些资料通常上来就会介绍诸如”Form认证“”Windows认证“等内容,而没有给出一个完整的流程.初学者对此往往一头雾水,我也曾经被坑过很 ...
- Java Performance - 如何调查解决内存问题
JVM 的内存溢出/不足/OutOfMemoryError/垃圾收集恶性循环是需要解决,又是屡见不鲜的问题. 建议阅读官方的 Troubleshooting Guide for Java SE 6 w ...