【NOIP2016提高A组模拟9.15】Osu
题目
分析
考虑二分答案,
二分小数显然是不可取的,那么我们将所有可能的答案求出来,记录在一个数组上,排个序(C++调用函数很容易超时,手打快排,时间复杂度约为\(O(>8*10^7)\),但相信梦想的力量)。
剩下就简单了,将二分出的值判断是否可以获得k分以上,
这里可以用多种方法,spfa、dp
dp:
\(dp_i\)表示移动到了第i个点的最大分数
#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const long long maxlongint=2147483647;
const long long mo=1000000007;
const long long N=2005;
using namespace std;
long long ans,a[N][3],n,m,tot,f[N];
double sum[N][N];
struct ddx
{
long long a,b,c;
double ans;
}d[N*N];
double cale(ddx x)
{
return 1.0*x.a*sqrt(x.b)/x.c;
}
bool cmp(ddx x,ddx y)
{
return x.ans<y.ans;
}
void q(int l,int r)
{
int i=l,j=r,e1;
double mid=d[(l+r)/2].ans;
double e;
while(i<j)
{
while(d[i].ans<mid) i++;
while(d[j].ans>mid) j--;
if(i<=j)
{
e1=d[i].a;
d[i].a=d[j].a;
d[j].a=e1;
e1=d[i].b;
d[i].b=d[j].b;
d[j].b=e1;
e1=d[i].c;
d[i].c=d[j].c;
d[j].c=e1;
e=d[i].ans;
d[i].ans=d[j].ans;
d[j].ans=e;
i++;
j--;
}
}
if(i<r) q(i,r);
if(l<j) q(l,j);
}
bool ok(double x)
{
memset(f,0,sizeof(f));
for(long long i=1;i<=n;i++)
{
for(long long j=0;j<=i-1;j++)
{
if(sum[i][j]<=x)
{
f[i]=max(f[i],f[j]+1);
}
}
if(f[i]>=m)
return true;
}
return false;
}
long long gcd(long long x,long long y)
{
return x==0?y:gcd(y%x,x);
}
int work(int x)
{
for(long long i=sqrt(d[x].b);i>=1;i--)
{
if(d[x].b%(i*i)==0)
{
d[x].b/=i*i;
d[x].a*=i;
break;
}
}
long long k=gcd(d[x].a,d[x].c);
if(!k) return 0;
d[x].a/=k;
d[x].c/=k;
}
double rf(long long l,long long r)
{
while(l<r)
{
long long mid=(l+r)/2;
if(ok(d[mid].ans))
r=mid;
else
l=mid+1;
}
work(l);
printf("%lld %lld %lld",d[l].a,d[l].b,d[l].c);
}
int main()
{
scanf("%lld%lld",&n,&m);
for(long long i=1;i<=n;i++)
for(long long j=0;j<=2;j++)
{
scanf("%lld",&a[i][j]);
}
for(long long i=0;i<=n-1;i++)
for(long long j=i+1;j<=n;j++)
{
d[++tot].a=1;
d[tot].b=(a[j][1]-a[i][1])*(a[j][1]-a[i][1])+(a[j][2]-a[i][2])*(a[j][2]-a[i][2]);
d[tot].c=a[j][0]-a[i][0];
d[tot].ans=cale(d[tot]);
sum[i][j]=sum[j][i]=d[tot].ans;
}
q(1,tot);
rf(1,tot);
}
【NOIP2016提高A组模拟9.15】Osu的更多相关文章
- 【JZOJ4783】【NOIP2016提高A组模拟9.15】Osu
题目描述 输入 输出 样例输入 4 2 1 2 2 2 0 2 3 0 0 4 2 0 样例输出 1 2 1 数据范围 样例解释 圆圈只在出现的时刻有效.即:时刻t_i时鼠标位置恰好在(x_i,y_i ...
- NOIP2016提高A组模拟10.15总结
第一题,就是将原有的式子一步步简化,不过有点麻烦,搞了很久. 第二题,枚举上下边界,维护一个单调队列,二分. 比赛上没有想到,只打了个暴力,坑了80分. 第三题,贪心,最后的十多分钟才想到,没有打出来 ...
- 【NOIP2016提高A组模拟10.15】打膈膜
题目 分析 贪心, 先将怪物按生命值从小到大排序(显然按这个顺序打是最优的) 枚举可以发对少次群体攻击, 首先将所有的群体攻击发出去, 然后一个一个怪物打,当当前怪物生命值大于2,如果还有魔法值就放重 ...
- 【NOIP2016提高A组模拟10.15】最大化
题目 分析 枚举两个纵坐标i.j,接着表示枚举区域的上下边界, 设对于每个横坐标区域的前缀和和为\(s_l\),枚举k, 显然当\(s_k>s_l\)时,以(i,k)为左上角,(j,k)为右下角 ...
- 【NOIP2016提高A组模拟10.15】算循环
题目 分析 一步步删掉循环, 首先,原式是\[\sum_{i=1}^n\sum_{j=1}^m\sum_{k=i}^n\sum_{l=j}^m\sum_{p=i}^k\sum_{q=j}^l1\] 删 ...
- 【NOIP2016提高A组模拟9.15】Map
题目 分析 发现,当原图是一棵树的时候,那么新建一条边后,就会变成环套树, 而环内的所有点对都是安全点对,如果环中有k个点,答案就是\(k(k-1)\) 联想到,当把原图做一遍tarjan缩点,每个环 ...
- 【NOIP2016提高A组模拟9.15】Math
题目 分析 因为\((-1)^2=1\), 所以我们只用看\(\sum_{j=1}^md(i·j)\)的值模2的值就可以了. 易证,一个数x,只有当x是完全平方数时,d(x)才为奇数,否则为偶数. 那 ...
- 【NOIP2016提高A组模拟8.15】Garden
题目 分析 其实原题就是[cqoi2012][bzoj2669]局部极小值. 有一个n行m列的整数矩阵,其中1到nm之间的每个整数恰好出现一次.如果一个格子比所有相邻格子(相邻是指有公共边或公共顶点) ...
- 【NOIP2016提高A组模拟8.15】Throw
题目 分析 首先对于一个状态(a,b,c),假定a<=b<=c: 现在考虑一下这个状态,的转移方案: \[1,中间向两边跳(a,b,c)-->(a*2-b,a,c).(a,b,c)- ...
随机推荐
- Hibernate 持久化对象和一级缓存
关于如何手动创建Hibernate,Hibernate初了解已经介绍了,接下来了解持久化对象和一级缓存. Hibernate的持久化类有三种状态: 1.Transient瞬时态:持久化对象没有唯一标识 ...
- DateTime相关
1.string数据转成datetime DateTimeFormatter forPattern = DateTimeFormat.forPattern("yyyyMMddHH" ...
- LeetCode.993-二叉树中的堂兄弟(Cousins in Binary Tree)
这是悦乐书的第374次更新,第401篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第235题(顺位题号是993).在二叉树中,根节点在深度0处,并且每个深度为k的节点的子 ...
- 【转】WEB技术发展简史
[转]WEB技术发展简史 一.Web技术发展的第一阶段——静态文档 第一阶段的Web,主要是用于静态Web页面的浏览.用户使用客户机端的Web浏览器,可以访问Internet上各个Web站点,在每一个 ...
- for循环实现九九乘法表
<!--for循环实现九九乘法表--> <table border="> <tbody> {% for x in range(1,10) %} <t ...
- python 并发编程 基于gevent模块实现并发的套接字通信
之前线程池是通过操作系统切换线程,现在是程序自己控制,比操作系统切换效率要高 服务端 from gevent import monkey;monkey.patch_all() import geven ...
- MyBatis批量插入性能及问题
1.mybatis三种批量插入方式对比 2.Mybatis与JDBC批量插入MySQL数据库性能测试及解决方案 3.Mybatis批量插入引发的血案 4.Oracle批量插入数据SQL语句太长出错
- [转帖]2018年全球ERP软件行业市场规模与发展趋势分析 云ERP将兴起【组图】
2018年全球ERP软件行业市场规模与发展趋势分析 云ERP将兴起[组图] https://www.qianzhan.com/analyst/detail/220/190215-4b1d6868.ht ...
- JNDI的初步理解
1.JDNI是什么意思? 答:JNDI是 java naming and directory interface 的缩写,是j2ee开发中的一种重要的规范 2.JNDI有什么用? 答:如果没有JNDI ...
- redis 哈希 数据类型
哈希 hset 设置哈希表字段 hset 8000 ename tom hset 8000 job salesman hget 8000 ename "tom" hget ...