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. POJ 1678

    博弈题,使用DP来完成.开始时,我以为可以用极大极小加剪枝可以过,但,TLE... 看过一些题解,没看懂,但也由此有了启发: 我们只记录差(初始为0),那为1选的数即为在原差值上加上该数,2选即是减去 ...

  2. iOS开发——定制圆形头像与照相机图库的使用

    如今的App都很流行圆形的头像,比方QQ右上角的头像,今日头条的头像等等.这已经成为App设计的趋势了.今天我们就来简单实现一下这个功能,我还会把从手机拍照中或者图库中取出作为头像的照片存储到应用程序 ...

  3. RDLC报表钻取空白页问题

    在改动报表查询条件时,钻取页突然空白了,百思不得其解,之前好好的,研究了一个下午和一个晚上.查资料等等,网上非常多资料都是设置报表的 ConsumeConteinerWhitespace = True ...

  4. oc23--变量修饰符

    // // Person.h #import <Foundation/Foundation.h> /* @public:所有类访问 @private:本类访问 @protected:本类子 ...

  5. chromium添加flash

    http://blog.csdn.net/lainegates/article/details/27830333

  6. Android5.1 在init.rc 中添加自己的服务【转】

    本文转载自:http://blog.csdn.net/VOlsenBerg/article/details/71085610 我有一个需求就是在Android系统开机的时候把一个配置文件放到Andro ...

  7. JAVA 中for-each循环使用方法

    for each循环还是第一次见,“java SE 5.0增加了一种功能很强的循环结构,可以用来一次处理数组中的每个元素(其他类型的元素集合亦可)而不必为指定下标值而分心”. 这种增强的for eac ...

  8. 2015 多校赛 第二场 1002 (hdu 5301)

    Description Your current task is to make a ground plan for a residential building located in HZXJHS. ...

  9. LeetCode Weekly Contest 24

    1, 543. Diameter of Binary Tree 维护左右子树的高度,同时更新结果,返回以该节点结束的最大长度.递归调用. /** * Definition for a binary t ...

  10. SQLServer Union 和 Union All 在Insert 语句中的不同效果

    如果不是发了那个帖子还不会像这样意外发现这两者的不同,好歹了也工作了一段时间,真是汗颜 上例子: 执行此条插入语句后,只会插入两条数据,因为会把完全重复的数据过滤掉 insert into tests ...