T1

打表出奇迹,发现结论为\(E(a_n)=n+1\)即可。

#include <iostream>
#include <cstdio>
#include <cctype>
#include <cstring>
using namespace std;
int n,Q;
long long rd() {
long long x=0,f=1;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-1;ch=getchar();}
while(isdigit(ch)) {x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int main() {
Q=rd();
while(Q--) {printf("%lld\n",rd()+1);}
}

T2

正解应该是kmp,求出来nxt数组为偶数的就行了。但是蒟蒻了一下,并且受到200000的数据范围引导,写了个nlogn的做法,对于每个位置能延伸出去的长度,二分一下,check一下hash即可,荣幸成为全场除了写SA的老哥以外跑的最慢的。。。全场唯一一个hash+二分。。。(自从写单hash被卡后老老实实写双hash)

UPD:单hash并没有被卡。。

#include <algorithm>
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
long long n,m,ans;
char s[200005];
struct Hsh{
unsigned long long hsh[200005],fac[200005],mod,p;
void build(unsigned long long M,unsigned long long P) {
mod=M,p=P;
fac[0]=1;
for(int i=1;i<=n;i++) {hsh[i]=(hsh[i-1]*p+s[i]-'a'+1)%mod;fac[i]=fac[i-1]*p%mod;}
}
unsigned long long gethash(int l,int r){return (hsh[r]-hsh[l-1]*fac[r-l+1]%mod+mod)%mod;}
}hsh1,hsh2;
struct Node{unsigned long long h1,h2;bool operator ==(const Node &rhs) const {return h1==rhs.h1&&h2==rhs.h2;}}h[100005],t;
Node gethsh(int l,int r) {return {hsh1.gethash(l,r),hsh2.gethash(l,r)};}
unsigned long long h1[200005],h2[200005];
void ck(int pos) {int l=1,r=n/2,mid,dd=0;while(l<=r) {mid=l+r>>1;if(h[mid]==gethsh(pos,pos+(mid<<1)-1)) l=mid+1,dd=mid;else r=mid-1;}ans+=dd;}
int main() {
scanf("%s",s+1);n=strlen(s+1);
hsh1.build(1e9+7,31);hsh2.build(1e9+9,37);
for(int i=2;i<=n;i+=2) h[i>>1]=gethsh(1,i);
for(int i=1;i<=n;i++)ck(i);
cout<<ans<<endl;
}

T3

讲过

#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#define init for(int O=1;O<=n;O++) fa[O]=O;
using namespace std;
int n,m,fa[1005];
struct Node{int ans,l;bool operator < (const Node &rhs)const {return (ans==rhs.ans)?(l>rhs.l):(ans<rhs.ans);}}ans;
int find(int x) {return x==fa[x]?x:fa[x]=find(fa[x]);}
struct Edge{int a,b,l,r;}e[3005];
bool cmp(Edge x,Edge y) {return x.r>y.r;}
int main() {
scanf("%d%d",&n,&m);
ans.ans=0,ans.l=0;
for(int i=1;i<=m;i++) scanf("%d%d%d%d",&e[i].a,&e[i].b,&e[i].l,&e[i].r);
sort(e+1,e+1+m,cmp);
for(int i=1,u,v;i<=m;i++) {
init
for(int j=1;j<=m;j++) {
if(e[j].l<=e[i].l) {
u=find(e[j].a),v=find(e[j].b),fa[u]=v;
if(find(1)==find(n)) {ans=max(ans,{e[j].r-e[i].l+1,e[i].l});break;}
}
}
}
printf("%d\n",ans.ans);for(int i=ans.l;i<=ans.l+ans.ans-1;i++) printf("%d ",i);
}

[2018.8.12]模拟赛B组的更多相关文章

  1. 2018.8.6 模拟赛 提高组B

    T1 Description 给定一个n个点m条边的有向图,有k个标记点,要求从规定的起点按任意顺序经过所有标记点到达规定的终点,问最短的距离是多少. Input 第一行5个整数n.m.k.s.t,表 ...

  2. 2018.12.30【NOIP提高组】模拟赛C组总结

    2018.12.30[NOIP提高组]模拟赛C组总结 今天成功回归开始做比赛 感觉十分良(zhōng)好(chà). 统计数字(count.pas/c/cpp) 字符串的展开(expand.pas/c ...

  3. [10.12模拟赛] 老大 (二分/树的直径/树形dp)

    [10.12模拟赛] 老大 题目描述 因为 OB 今年拿下 4 块金牌,学校赞助扩建劳模办公室为劳模办公室群,为了体现 OI 的特色,办公室群被设计成了树形(n 个点 n − 1 条边的无向连通图), ...

  4. 2017.1.16【初中部 】普及组模拟赛C组总结

    2017.1.16[初中部 ]普及组模拟赛C组 这次总结我赶时间,不写这么详细了. 话说这次比赛,我虽然翻了个大车,但一天之内AK,我感到很高兴 比赛 0+15+0+100=115 改题 AK 一.c ...

  5. NOIP2020 模拟赛 B 组 Day6

    非常巧妙的一场模拟赛,比较偏向于 Atcoder 的风格,考场上做出了 A .C 两题. A. 礼物购买 排完序后一个个礼物地枚举时间复杂度是\(\Theta(nm)\)的,不能接受.但是注意到,若当 ...

  6. 2018.10.17NOIP模拟赛解题报告

    心路历程 预计得分:\(100 + 100 +100\) 实际得分:\(100 + 100 + 60\) 辣鸡模拟赛.. 5min切掉T1,看了一下T2 T3,感觉T3会被艹爆因为太原了.. 淦了20 ...

  7. 2018 蓝桥杯省赛 B 组模拟赛(五)

    A模拟 代码1 #include<bits/stdc++.h> using namespace std; int n = 101; int a[120][120]; int ans = 0 ...

  8. 2020.09.12【NOIP提高组&普及组】模拟赛C组 总结

    总结:这次比赛成绩并不理想,虽然策略得当 \(P.S.\):太多题有多组数据,但是样例只有一个数据 各题题解和改题情况 T1 匹配 题面 描述 给你一个由{a,b-z,A,B-.Z}组成的字符串,我们 ...

  9. 计蒜客2018 蓝桥杯省赛 B 组模拟赛(一)

    1,结果填空:年龄 今天蒜头君带着花椰妹和朋友们一起聚会,当朋友们问起年龄的时候,蒜头君打了一个哑谜(毕竟年龄是女孩子的隐私)说:“我的年龄是花椰妹年龄个位数和十位数之和的二倍”. 花椰妹看大家一脸懵 ...

随机推荐

  1. 消息队列Rabbit安装

    先安装elang 再安装Rabbit *Rabbit安装路径不能有空格 安装完成

  2. asp.net--ado.net5大对象代码示例

    连接数据库 string conn_string ="Data Source=localhost;Initial Catalog=SQLtest;Integrated Security=Tr ...

  3. HDU 4513 manacher

    Manacher算法,相当于求回文串. 关于Manacher,转 http://blog.sina.com.cn/s/blog_70811e1a01014esn.html 现在进入正题:首先,在字符串 ...

  4. eclipse配置默认的jdk

    1.window-preferences-java-Installed JREs-Add-Standard VM-[添加jre6或jre7的路径]

  5. c16---字符串

    // // main.c // 字符串的基本概念,字符串和字符数组的共用的char[], #include <stdio.h> int main(int argc, const char ...

  6. Android的编译环境--Build系统【转】

    本文转载自:http://blog.csdn.net/kitty_landon/article/details/60764232 Android是一个庞大的系统,包含太多的模块,各种模块的类型也有10 ...

  7. 详解Google第二代TPU 既能推理又能训练 性能霸道

    详解Google第二代TPU 既能推理又能训练 性能霸道 转自:http://www.cnbeta.com/articles/tech/613639.htm 5月18日凌晨,Google CEO Su ...

  8. nyoj--92--图像有用区域(模拟)

    图像有用区域 时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描述 "ACKing"同学以前做一个图像处理的项目时,遇到了一个问题,他需要摘取出图片中某个黑 ...

  9. Html+CSS基础之Html

    注:本文摘自慕课网http://www.imooc.com   HTML+CSS基础课程 本人有道笔记:http://note.youdao.com/noteshare?id=18fa811e9f9e ...

  10. 深入了解Token认证的来龙去脉

    Token 是在服务端产生的,如果前端使用用户名/密码向服务端请求认证,服务端认证成功,那么在服务端会返回 Token 给前端.前端可以在每次请求的时候带上 Token 证明自己的合法地位.   不久 ...