【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)才能得分。
Kaguya所做的工作就是在这些时刻间移动鼠标。
对于样例:选择点击第2、4个圆圈。
时间[0,2]内,鼠标从(0,0)移动到(0,2),速度为1,并在时刻2得分。
时间[2,4]内,鼠标从(0,2)移动到(2,0),速度为sqrt(2),并在时刻4得分。
因此答案为sqrt(2), a=1 b=2 c=1
解法
二分最大速度的取值,有n^2种。
再利用动态规划解决判定性问题。
注意卡常。
代码
#include<iostream>
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<algorithm>
#include<stdlib.h>
#include<time.h>
#define ll long long
#define ln(x,y) int(log(x)/log(y))
#define sqr(x) ((x)*(x))
#define random(x) (rand()%x)
using namespace std;
const char* fin="aP2.in";
const char* fout="aP2.out";
const int inf=0x7fffffff;
const int maxn=2007,maxtot=maxn*maxn;
int n,m,i,j,k,tot,l,r,mid,cnt;
struct node{
int t,x,y;
}a[maxn];
int gcd(int a,int b){
if (b) return gcd(b,a%b);
else return a;
}
struct fuck{
int a,b,c;
fuck(){
a=b=c=0;
}
double val(){
if (c==0) return inf;
return a*sqrt(b)/c;
}
bool operator <=(const fuck& b1){
return (ll)sqr(a)*b*sqr(b1.c)<=(ll)sqr(b1.a)*b1.b*sqr(c);
}
bool operator <(const fuck& b1){
return (ll)sqr(a)*b*sqr(b1.c)<(ll)sqr(b1.a)*b1.b*sqr(c);
}
bool operator >(const fuck& b1){
return (ll)sqr(a)*b*sqr(b1.c)>(ll)sqr(b1.a)*b1.b*sqr(c);
}
void operator =(const fuck& b1){
a=b1.a;
b=b1.b;
c=b1.c;
}
void print(){
int i,j,k;
for (i=2;i<=int(sqrt(b));i++){
while (b%sqr(i)==0){
a*=i;
b/=sqr(i);
}
}
k=gcd(a,c);
a/=k;
c/=k;
printf("%d %d %d",a,b,c);
}
}b[maxn*maxn];
bool cmp(fuck a,fuck b){
return a<b;
}
fuck dist(int sx,int sy,int tx,int ty,int t){
fuck A;
A.a=1;
A.b=sqr(sx-tx)+sqr(sy-ty);
A.c=t;
return A;
}
fuck dist(int x,int y){
fuck A;
A.a=1;
A.b=sqr(a[x].x-a[y].x)+sqr(a[x].y-a[y].y);
A.c=abs(a[x].t-a[y].t);
return A;
}
int f[maxn],g[maxn];
fuck tmd,tmp;
bool judge(fuck ans){
int i,j,k;
f[0]=0;
g[0]=0;
for (i=1;i<=n;i++){
f[i]=0;
for (j=i-1;j>=0;j--){
if (f[i]<g[j]+1){
cnt++;
if (dist(i,j)<=ans){
f[i]=max(f[j]+1,f[i]);
}
}
}
g[i]=max(f[i],g[i-1]);
}
return f[n]>=m;
}
void qsort(int l,int r){
int i=l,j=r,k=l+(r-l)/2;
fuck mid=b[k];
while (i<=j){
while (b[i]<mid) i++;
while (b[j]>mid) j--;
if (i<=j){
swap(b[i],b[j]);
i++;
j--;
}
}
if (l<j) qsort(l,j);
if (i<r) qsort(i,r);
}
int main(){
srand(time(0));
scanf("%d%d",&n,&m);
a[0].t=a[0].x=a[0].y=0;
for (i=1;i<=n;i++){
scanf("%d%d%d",&a[i].t,&a[i].x,&a[i].y);
}
b[++tot].a=0;b[tot].b=0;b[tot].c=1;
for (i=0;i<=n;i++) {
tmd.a=tmd.b=tmd.c=0;
for (j=i+1;j<=n;j++) {
tmp=dist(i,j);
if (tmd<tmp) continue;
b[++tot]=tmp;
tmd=tmp;
}
}
sort(b+1,b+tot+1,cmp);
l=1;
r=tot;
k=0;
while (l<r){
k++;
mid=(l+r)/2;
if (judge(b[mid])) r=mid;
else l=mid+1;
}
//printf("%d %d\n",cnt,k);
b[l].print();
return 0;
}
启发
最值套最值用二分,当数值不能二分时,考虑取值。
卡常时去除冗余状态。
【JZOJ4783】【NOIP2016提高A组模拟9.15】Osu的更多相关文章
- 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】Osu
题目 分析 考虑二分答案, 二分小数显然是不可取的,那么我们将所有可能的答案求出来,记录在一个数组上,排个序(C++调用函数很容易超时,手打快排,时间复杂度约为\(O(>8*10^7)\),但相 ...
- 【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)- ...
随机推荐
- spring cloud深入学习(九)-----配置中心服务化和高可用
在前两篇的介绍中,客户端都是直接调用配置中心的server端来获取配置文件信息.这样就存在了一个问题,客户端和服务端的耦合性太高,如果server端要做集群,客户端只能通过原始的方式来路由,serve ...
- volatile和指令重排序
volatile 的作用 1 精致指令重排序 2 多线程访问同一个变量的时候,每次都是取最新的,而不会使用当前cpu缓存的那一份.
- 记一次msf入侵win10,并拍照
好久没有玩kali了,刚才看到一位大佬msf渗透win10的思路,我感觉不错,我就来复现一下 kali :192.168.45.136 win10 : 192.168.45.137 1 首先,我们查 ...
- idea报错:Error:java不支持发行版本5的解决方法
将以下对应配置一致即可. File-->Project Structure File-->Settings
- JasperReport查看和打印报告7
报表填充过程JasperPrint对象的输出可以使用内置的浏览器组件来查看,打印或导出到更多的流行的文件格式,如PDF,HTML,RTF,XLS,ODT,CSV或XML.Jasper文件查看和打印将包 ...
- Leetcode476.Number Complement数字的补数
给定一个正整数,输出它的补数.补数是对该数的二进制表示取反. 注意: 给定的整数保证在32位带符号整数的范围内. 你可以假定二进制数不包含前导零位. 示例 1: 输入: 5 输出: 2 解释: 5的二 ...
- Django定义全局变量
定义全局变量,在项目的任何位置都可以获取到变量的值 在include App=>include文件夹下=>context_processors.py 里定义需要获取的变量 #!/usr/b ...
- MaxCompute 最新特性介绍 | 2019大数据技术公开课第三季
摘要:距离上一次MaxCompute新功能的线上发布已经过去了大约一个季度的时间,而在这一段时间里,MaxCompute不断地在增加新的功能和特性,比如参数化视图.UDF支持动态参数.支持分区裁剪.生 ...
- AT2164 Rabbit Exercise
传送门 解题思路 首先考虑k=1的情况,对于每一个a[i],它可能会到a[i-1]*2-a[i] 与 a[i+1]*2-a[i]两个位置,概率都为%50,那么它的期望位置为 (a[i-1]*2-a[i ...
- TZ_05_Spring_annotation常见注解
Spring常用的注解大全和解释 注解 解释 @Controller 组合注解(组合了@Component注解),应用在MVC层(控制层),DispatcherServlet会自动扫描注解了此注解的类 ...