四连测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的定时器编码器接口模式对编码器进行四倍频, ...
随机推荐
- .NET MVC和.NET WEB api混用时注意事项
1.同时配置了mvc路由和api路由时,mvc路由无法访问(调用所有mvc路由全部404错误) 在Global.asax中,需注意路由注册的顺序,将api路由注册放在最后: 即将 void Appli ...
- SQL语言重点学习
数据库的操作任务通常包括以下几个方面: 1.查询数据. 2.在表中插入,修改和删除记录. 3.建立,修改和删除数据对象. 4.控制对数据和数据对象的读写. 5.保证数据库一致性和完整性. SQL语言学 ...
- 拓扑排序 (Ordering Tasks UVA - 10305)
题目描述: 原题:https://vjudge.net/problem/UVA-10305 题目思路: 1.依旧是DFS 2.用邻接矩阵实现图 3.需要判断是否有环 AC代码 #include < ...
- vue学习笔记之:为何data是一个方法
vue学习笔记之:为何data是一个方法 在vue开发中,我们可以发现,data中的属性值是在function中return出来的.可为何data必须是一个函数呢?我们先看官方的解释: 当一个组件被定 ...
- Python中函数的参数-arguments
归纳起来,Python中函数的定义形式和调用形式主要有如下几种形式: # 函数的定义形式 def func(name) # 匹配positional参数或者keyword参数 def func(nam ...
- ptrdiff_t类型
一.特性 1. 这是一种标准库类型 2. 是两个指针相减的结果的类型(因为差值可能为负值,所以是一种带符号类型) 3. 和size_t一样,ptrdiff_t也是一种定义在<cstddef> ...
- 2019寒假训练营第三次作业part1-网络空间安全概论第五章
第五章 网络攻防技术 5.1 网路信息收集技术--网络踩点 黑客入侵系统之前,需要了解目标系统可能存在的: 管理上的安全缺陷和漏洞 网络协议安全缺陷与漏洞 系统安全缺陷与漏洞 黑客实施入侵过程中,需要 ...
- MFC修改视图CView的背景颜色
(1) 在CYournameView(就是你的视图类,以下以CDrawLineView为例)添加了一个背景颜色变量 COLORREF m_bgcolor; (2)修改这个函数: BOOL CDrawL ...
- css那些事儿3 列表与浮动
一 列表 列表默认为行内块元素,具有宽高,当一个非块元素是无法应用宽高的,比如a 1 有序列表 有ol li组成,其中li为列表项,列表的ol子元素务必为li元素标签,li子内容支持列表任意嵌套,有 ...
- YaoLingJump开发者日志(四)
这么有意思的游戏没有剧情怎么行?开始剧情的搭建. 用到了LGame中的AVGScreen,确实是个好东西呢,只需要准备图片和对话脚本就行了. 经过不断的ps,yy,ps,yy,游戏开头的剧 ...