四连测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的定时器编码器接口模式对编码器进行四倍频, ...
随机推荐
- 第三模块:面向对象&网络编程基础 第4章 FTP项目作业讲解
01-FTP项目需求 02-FTP项目框架搭建 03-FTP项目用户认证 04--FTP项目制定标准定长消息头 05-FTP项目下载功能开发 06-FTP项目下载功能开发2 07-FTP项目ls文件列 ...
- hackerrank Project Euler #210: Obtuse Angled Triangles
传送门 做出一个好几个星期屯下来的题目的感觉就是一个字: 爽! 上图的黄点部分就是我们需要求的点 两边的部分很好算 求圆的地方有一个优化,由于圆心是整数点,我们可以把圆分为下面几个部分,阴影部分最难算 ...
- Python入门(5)
导览: 函数 集合 迭代器与生成器 模块 一.函数 只要学过其他编程语言应该对函数不太陌生,函数在面向过程的编程语言中占据了极重要的地位,可以说没有函数,就没有面向过程编程,而在面向对象语言中,对象的 ...
- 第一周 Welcome
什么是机器学习 您也许一天用它几十次都不知道,每次你用google或者bing搜索网页感觉很厉害,因为他们用机器学习软件来设计网页排名,当你用Facebook或Apple的照片软件而它们知道照片里面哪 ...
- 【转】CentOS: 开放80、22、3306端口操作
#/sbin/iptables -I INPUT -p tcp --dport 80 -j ACCEPT#/sbin/iptables -I INPUT -p tcp --dport 22 -j AC ...
- appcan打包后产生的问题总结
以appcan为基础的项目,最终需要打包后进行调试.在调试过程中,主要的样式问题在苹果手机上,下面将这些问题总结起来,以防下次再犯. 1:ios 7 以上的手机中,状态栏与内容重叠: 问题描述:在io ...
- JS设置cookie,删除cookie(引)
JS设置cookie,删除cookie(引) js设置cookie有很多种方法. 第一种:(这个是w3c官网的代码) <script> //设置cookie function setCoo ...
- (转)apktool+dex2jar+jd_gui
转:http://www.cnblogs.com/MichaelGuan/archive/2011/10/25/2224578.html apktool: 可以解析资源文件,比如布局文件xml等,方便 ...
- xml解析----java中4中xml解析方法(转载)
转载:https://www.cnblogs.com/longqingyang/p/5577937.html 描述 XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与 ...
- iOS如何做出炫酷的翻页效果
详情链接http://www.jianshu.com/p/b6dc2595cc3e https://github.com/schneiderandre/popping