题目:链接: 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的更多相关文章

  1. 四连测Day4

    四连爆炸 卡我常数 好像被AluminumGod拉到了创客...哇我这个天天爆炸的水平可能会被其他三位dalao吊起来打 orz Edmond-Karp_XiongGod orz Deidara_Wa ...

  2. 【2018.8.10】四连测day4 题解

    T1:给出一棵 $n$ 个节点的无根树,其中 $m$ 个节点是特殊节点,求对于任意 $i ∈ [0, m]$,包含 $i$ 个特殊节点的联通块个数$\mod 998244353$. $1<=n, ...

  3. 四连测总结(XYX)

    目录 成绩 总结 事后... 成绩 telephonewire monkey 总分 0 56 56 cowjog guard path temperature 总分 0 40 0 68 108 cba ...

  4. 正睿 2018 提高组十连测 Day2 T2 B

    题目链接 http://www.zhengruioi.com/contest/84/problem/318 题解写的比较清楚,直接扒过来了. B 算法 1 直接按题意枚举,动态规划或是记忆化搜索. 时 ...

  5. 四连测Day3

    题目链接:https://pan.baidu.com/s/1_vsHfMI_qO-9IDxmFLkHfg 密码: uza8 T1: 小奥的一笔画,判连通性,查奇偶点即可 #include<ios ...

  6. 四连测Day1

    题目:链接: https://pan.baidu.com/s/163ycV64ioy7uML7AvRDTGw 密码: p86i T1: 倍增求LCA,minn数组记录最小值 #include<i ...

  7. ZROI 提高十连测 DAY2

    总结:入题尽量快,想到做法要先证明是否正确是否有不合法的情况,是否和题目中描述的情景一模一样.    不要慌 反正慌也拿不了多少分,多分析题目的性质如果不把题目的性质分析出来的话,暴力也非常的难写,有 ...

  8. (四连测)滑雪场的高度差题解---二分 + 搜索---DD(XYX)​​​​​​​的博客

    滑雪场的高度差 时间限制: 1 Sec  内存限制: 128 MB 题目描述 滑雪场可以看成M x N的网格状山地(1 <= M,N <= 500),每个网格是一个近似的平面,具有水平高度 ...

  9. STM32—TIMx实现编码器四倍频

    文章目录 一.储备知识 二.TIMx的编码器模式介绍 1.计数边沿设置 2.选择极性和使能 3.使能 4.计数方向 三.代码部分 一.储备知识 通过STM32的定时器编码器接口模式对编码器进行四倍频, ...

随机推荐

  1. Matlab R2016a 破解教程

    郑重声明:图片来源于网络,在这里感谢图片提供者,我写这篇教程,是希望帮助后来者少走弯路,而且,这是一种比较简单有效的破解方法,针对网上那种修改本地文件的方法,在这里不做介绍,如果想体验,可自己百度或谷 ...

  2. leetcode-零钱兑换—int溢出

     零钱兑换 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成总金额,返回 -1. 示例 1: 输入: c ...

  3. python3 SQLAlchemy模块使用

    更详细的操作介绍:https://www.imooc.com/article/22343 定义: SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对 ...

  4. 使用flume抓取tomcat的日志文件下沉到kafka消费

    Tomcat生产日志 Flume抓取日志下沉到kafka中 将写好的web项目打包成war包,eclise直接导出export,IDEA 在artifact中添加新的artifact-achieve项 ...

  5. maven 安装、配置

    简介: maven 大大提高项目开发速度     编译---打包---测试--安装   一条龙 maven将项目构建的过程标准化,每一个阶段使用一个命令完成,下面是构建过程一些阶段 清理 mvn cl ...

  6. css贝塞尔曲线模仿饿了么购物车小球动画

    在线观看贝塞尔曲线值:传送门 在线观看动画效果:传送门 代码: <!DOCTYPE html> <html> <head> <meta charset=&qu ...

  7. C语言 结构体相关 函数 指针 数组

    . 作者 : 万境绝尘 转载请注明出处 : http://www.hanshuliang.com/?post=30 . 结构体概述 : 结构体是 多个 变量的集合, 变量的类型可以不同; -- 可进行 ...

  8. 《JavaScript 高级程序设计》总结

    一.JS基本概念 1.命名规则 变量名区分大小写(test和Test是两个不同的变量名),标识符采用驼峰命名格式,即:第一个字母小写,剩下的每个有意义的单词首字母大写: 标识符第一个字符必须是以字母. ...

  9. ACM 第十五天

    计算几何基础 练习题 C - Wasted Time Mr. Scrooge, a very busy man, decided to count the time he wastes on all ...

  10. css那些事儿2 经典两列布局

    <!DOCTYPE html> <html> <head> <title></title> <link rel="style ...