四连测Day2
题目:链接: https://pan.baidu.com/s/1ef_9hGBhczW0B4dz5IUKmw 密码: qgjy
T1:
hash后直接二分查询即可
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
inline long long read()
{
long long f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return ans*f;
}
char str[];
long long sum[];
long long b[];
long long bb=;
long long maxn=;
long long l,r,mid;
long long u,v;
bool check(long long x)
{
long long x1=sum[u+x-]-sum[u-]*b[x];
// cout<<sum[u+x-1]<<" "<<sum[u-1]<<" "<<b[x]<<" "<<x1<<endl;
long long x2=sum[v+x-]-sum[v-]*b[x];
// cout<<sum[v+x-1]<<" "<<sum[v-1]<<" "<<b[x]<<" "<<x2<<endl;
return x1==x2;
}
int main()
{
b[]=;
for(int i=;i<=;i++) b[i]=b[i-]*bb;
scanf("%s",str+);
long long len=strlen(str+);
for(long long i=;i<=len;i++) sum[i]=sum[i-]*bb+(str[i]-'a'+);
long long n=read();
for(long long i=;i<=n;i++)
{
u=read(),v=read();
l=,r=len-max(u,v)+;
maxn=;
while(l<=r)
{
mid=(l+r)/;
if(check(mid))
{
maxn=max(maxn,mid);
l=mid+;
}else r=mid-;
}
printf("%d\n",maxn);
}
}
/*
aabaabab
1
2 7
*/
T2:
因为作者能力有限,数学技巧过于高深,所以先给std,学完以后再重新补写
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
inline int read()
{
int x=,t=,c;
while(!isdigit(c=getchar()))if(c=='-')t=-;
while(isdigit(c))x=x*+c-'',c=getchar();
return x*t;
}
int sig(long long x)
{
if(x<)return -;
else if(!x)return ;
return ;
}
long long gcd(long long a,long long b){return b?gcd(b,a%b):a;}
class Vector
{
public:
long long x,y;
Vector(long long _x=,long long _y=)
{
x=_x;
y=_y;
}
Vector operator + (const Vector &b) const
{
return Vector(x+b.x,y+b.y);
}
Vector operator - (const Vector &b) const
{
return Vector(x-b.x,y-b.y);
}
long long operator * (const Vector &b) const
{
return x*b.x+y*b.y;
}
};
class Line
{
public:
long long a,b,c;
Line(Vector v0,Vector v1)
{
a=v0.x-v1.x;
b=v0.y-v1.y;
swap(a,b);
a=-a;
c=gcd(a,b);
a/=c;
b/=c;
c=a*v0.x+b*v0.y;
}
Line(long long _a=,long long _b=,long long _c=)
{
a=_a;
b=_b;
c=_c;
}
int side(Vector v)
{
return sig(v*Vector(a,b)-c);
}
}l1,l2;
void Solve()
{
int n=read();
Vector v0,v1,u0,u1;
v0.x=read();v0.y=read();v1.x=read();v1.y=read();
l1=Line(v0,v1);
bool res=;
while(n--)
{
u0.x=read();u0.y=read();u1.x=read();u1.y=read();
l2=Line(u0,u1);
if(l1.a*l2.b==l1.b*l2.a)
{
if(l1.c*l2.b==l2.c*l1.b)
{
long long l0=,r0=(v1-v0)*(v1-v0),l1=(u0-v0)*(v1-v0),r1=(u1-v0)*(v1-v0);
if(l0<=r1&&l1<=r0)res=;
}
}
else
{
if(l1.side(u0)!=l1.side(u1)&&l2.side(v0)!=l2.side(v1))res=;
}
}
if(res)puts("YES");
else puts("NO");
}
int main()
{
freopen("intersect.in","r",stdin);
freopen("intersect.out","w",stdout);
int T=read();
while(T--)Solve();
}
std
T3:
dijkstra倒推,加优先队列优化,设dis[n]=0,dis[i]=min{dis[i],max(最大限制,dis[x(i为起点的终点)]+所对应需要的能量)}
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
using namespace std;
inline long long read()
{
long long f=,ans=;char c;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){ans=ans*+c-'';c=getchar();}
return ans*f;
}
priority_queue<pair<long long,long long > > que;
long long n,m,cnt=;
struct node{
long long a,b,c,m,nex;
}x[];
long long head[];
long long vis[];
long long dis[];
void add(long long u,long long v,long long c,long long m)
{
x[cnt].a=u,x[cnt].b=v,x[cnt].c=c,x[cnt].m=m;
x[cnt].nex=head[u],head[u]=cnt++;
}
long long inf;
int main()
{
memset(head,-,sizeof(head));
memset(dis,/,sizeof(dis));
inf=dis[];
n=read(),m=read();
for(long long i=;i<=m;i++)
{
long long u=read(),v=read(),c=read(),m=read();
add(u,v,c,m);
add(v,u,c,m);
}
dis[n]=;
que.push(make_pair(,n));
while(!que.empty())
{
long long xx=que.top().second;que.pop();
if(vis[xx]==) continue;
vis[xx]=;
for(long long i=head[xx];i!=-;i=x[i].nex)
{
if(dis[x[i].b]>max(x[i].m,dis[xx]+x[i].c))
{
dis[x[i].b]=max(x[i].m,dis[xx]+x[i].c);
que.push(make_pair(-dis[x[i].b],x[i].b));
} }
}
if(dis[]!=inf) cout<<dis[];
else cout<<-;
}
四连测Day2的更多相关文章
- 四连测Day4
四连爆炸 卡我常数 好像被AluminumGod拉到了创客...哇我这个天天爆炸的水平可能会被其他三位dalao吊起来打 orz Edmond-Karp_XiongGod orz Deidara_Wa ...
- 【2018.8.10】四连测day4 题解
T1:给出一棵 $n$ 个节点的无根树,其中 $m$ 个节点是特殊节点,求对于任意 $i ∈ [0, m]$,包含 $i$ 个特殊节点的联通块个数$\mod 998244353$. $1<=n, ...
- 四连测总结(XYX)
目录 成绩 总结 事后... 成绩 telephonewire monkey 总分 0 56 56 cowjog guard path temperature 总分 0 40 0 68 108 cba ...
- 正睿 2018 提高组十连测 Day2 T2 B
题目链接 http://www.zhengruioi.com/contest/84/problem/318 题解写的比较清楚,直接扒过来了. B 算法 1 直接按题意枚举,动态规划或是记忆化搜索. 时 ...
- 四连测Day3
题目链接:https://pan.baidu.com/s/1_vsHfMI_qO-9IDxmFLkHfg 密码: uza8 T1: 小奥的一笔画,判连通性,查奇偶点即可 #include<ios ...
- 四连测Day1
题目:链接: https://pan.baidu.com/s/163ycV64ioy7uML7AvRDTGw 密码: p86i T1: 倍增求LCA,minn数组记录最小值 #include<i ...
- ZROI 提高十连测 DAY2
总结:入题尽量快,想到做法要先证明是否正确是否有不合法的情况,是否和题目中描述的情景一模一样. 不要慌 反正慌也拿不了多少分,多分析题目的性质如果不把题目的性质分析出来的话,暴力也非常的难写,有 ...
- (四连测)滑雪场的高度差题解---二分 + 搜索---DD(XYX)的博客
滑雪场的高度差 时间限制: 1 Sec 内存限制: 128 MB 题目描述 滑雪场可以看成M x N的网格状山地(1 <= M,N <= 500),每个网格是一个近似的平面,具有水平高度 ...
- STM32—TIMx实现编码器四倍频
文章目录 一.储备知识 二.TIMx的编码器模式介绍 1.计数边沿设置 2.选择极性和使能 3.使能 4.计数方向 三.代码部分 一.储备知识 通过STM32的定时器编码器接口模式对编码器进行四倍频, ...
随机推荐
- Selenium自动化测试第一天(上)
如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...
- Python 函数参数类型大全(非常全!!!)
Python 函数参数类型大全(非常全!!!) 1.在python编写程序里面具有函数文档,它的主要作用是为了让别人可以更好的理解你的函数,所以这是一个好习惯,访问函数文档的方式是: MyFuncti ...
- C#-返回相对时间函数
在公司一直做前端,经理叫我写一个后端函数,要求是: 参数:DateTime--传入任意时间类型返回:string --返回传入参数时间与当前时间的相对时间字符串,如:3天前,1小时前,5分钟前. 注意 ...
- 【cover-view、cover-image】 覆盖组件说明
cover-view.cover-image 这两类覆盖组件用于显示在一些特殊组件上方(map.video.canvas.camera.live-player.live-pusher). 这类组件一般 ...
- Bootstrap栅格系统基本使用
1.什么是栅格系统: 在Bootstrap中,它提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列.栅格系统用于通过一系列的行(row ...
- 【CSVRead】-jmeter
csv read 读取文件
- 手机端网页返回顶部js代码
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" cont ...
- NOIP2019普及级别模拟 3.30校模拟
好吧我还是第一次写这种总结类的玩意… 考场心情…hmm…我没睡醒.是的是这样的,反正题都有两三个看错了或者没看懂… 最关键的是!!我!居!然!把!Freopen!写!在!了!程!序!最!后! 然后就和 ...
- scanf格式控制符的完整格式
scanf格式控制的完整格式: % * m l或h 格式字符 ①格式字符与printf函数中的使用方式相同,以%d.%o.%x.%c.%s.%f.%e,无%u格式.%g ...
- javaIO--文件操作类
文件操作类主要是使用File类的各种方法对文件和目录进行操作.包括文件名.文件长度.最后修改时间和是否只读等,提供获得当前文件的路径名.判断文件是否存在.创建.删除文件和目录等一系列的操作方法. 下面 ...