因为时间关系这把没设计题面,而且居然还出了锅……T_T

  原题是leetcode WeeklyContest52 的T1(懒得去找url了

  随便搞,但是无解输-1

数字统计

原题PE603

  记前n个素数组成的字符串为S

  一个数字可以分成三部分,中间一段恰好为S复制某次后的结果,前面一段S的后缀,后面一段S的前缀。这3个部分分开统计。

  对于每个部分,我们可以很容易写出一份暴力,然后用自然数k次前缀和的公式优化一波就可以了。

#include<ctime>
#include<cassert>
#include<cstdio>
#include<algorithm>
#define MN 2000001
#define int long long
#define ju(x) assert(1||(x)>=0&&x<MOD)
using namespace std; const int MOD=1e9+;
int p[MN],sum=,num=,K,mmh,s[MN],n,pre[MN],suf[MN];
bool bo[MN];
inline void M(int &x){while(x>=MOD)x-=MOD;while(x<)x+=MOD;}
inline int mi(long long x,long long y){
int mmh=;
while (y){
if (y&) mmh=1LL*mmh*x%MOD;
x=1LL*x*x%MOD;y>>=;
}
return mmh;
}
signed main(){
for (int i=;i<MN;i++){
if (!bo[i]) p[++num]=i;
for (int j=;j<=num&&i*p[j]<MN;j++)
if (bo[i*p[j]]=,i%p[j]==) break;
}
num=;K=1000000000000ll;
//freopen("data/count1.in","r",stdin);
//freopen("data/count1.out","w",stdout);
//num=10000;K=1000000000000ll;
//num=23;K=233;
scanf("%lld%lld",&num,&K);
mmh=n=;
for (int i=num;i;i--)
for (int j=p[i];j;j/=) s[n++]=j%;
for (int i=;i<n/;i++) swap(s[i],s[n--i]);
for (int i=;i<n;i++) M(pre[i]=pre[i-]*%MOD+s[i]);
for (int i=n-,k=;i>=;i--,k=1LL*k*%MOD) M(suf[i]=1LL*s[i]%MOD*k%MOD+suf[i+]); for (int i=,j=;i<n;i++)
j=(1LL*j%MOD*%MOD+1LL*s[i]%MOD*(i+)%MOD)%MOD,M(mmh+=j);
mmh=1LL*K%MOD*mmh%MOD;
for (int i=;i<n;i++) sum=(1LL*sum*+s[i])%MOD;
int MMH=1LL*K%MOD*((K-)%MOD)%MOD*mi(,MOD-)%MOD*%MOD,_MMH=,a=mi(,MOD-);
MMH=MOD-MMH;
ju(MMH);ju(_MMH); //for (int i=0;i<K;i++) _MMH=(1LL*i%MOD*mi(a,i*n)+_MMH)%MOD;
int b=mi(a,n);
M(_MMH=((1LL*(K-)%MOD*mi(b,K)+)%MOD*mi(b-,MOD-)%MOD-(1LL*mi(b,K)-)%MOD*mi(b-,MOD-)%MOD*mi(b-,MOD-)%MOD)%MOD);
ju(MMH);ju(_MMH); _MMH=1LL*_MMH%MOD*mi(,K*n-n+)%MOD;
M(mmh+=1LL*(MMH+_MMH)%MOD*n%MOD*sum%MOD*mi(,MOD-)%MOD);
ju(MMH);ju(_MMH);
for (int i=;i<n;i++){
int MMH=1LL*(mi(,K*n)-)%MOD*mi(mi(,n)-,MOD-)%MOD;
ju(MMH); MMH=MMH*%MOD;
M(MMH-=K*%MOD);
ju(MMH);
M(mmh+=suf[i]%MOD*mi(,MOD-)%MOD*MMH%MOD);
ju(mmh);
} for (int i=;i<n;i++){
int MMH=1LL*K%MOD*((K-)%MOD)%MOD*mi(,MOD-)%MOD;
ju(MMH);
M(mmh+=1LL*pre[i]%MOD*n%MOD*MMH%MOD);
ju(mmh);
}
printf("%lld\n",mmh);
return ; mmh=n=;
for (int k=;k<=K;k++)
for (int i=num;i;i--)
for (int j=p[i];j;j/=) s[n++]=j%;
for (int i=;i<n/;i++) swap(s[i],s[n--i]);
for (int i=,j=;i<n;i++)
j=(1LL*j%MOD*%MOD+1LL*s[i]%MOD*(i+))%MOD,M(mmh+=j);
printf("%lld\n",mmh);
return ; mmh=n=;
for (int k=;k<=K;k++)
for (int i=num;i;i--)
for (int j=p[i];j;j/=) s[n++]=j%;
for (int i=n-;i>=;i--)
for (int j=i,k=;j>=;j--)
k=(1LL*k*+s[j])%MOD,M(mmh+=k);
printf("%d\n",mmh);
}

飞翔

原题 Codility Chromium 2017

  首先把数字从大到小排个序,然后从1到n枚举以每棵树为起点的序列数,这样就每次只有一棵树从在右边的状态变成在左边的状态。

  问题变成,一列格子,一些是黑色的,一些是白色的,你需要从左往右走,每次可以走到当前格子右边的任意一个点,相邻两次踩到的格子必须颜色不同。这个问题显然可以直接递推。考虑到要进行修改操作,我们可以用线段树维护矩阵乘法实现。

  出题人写了3次觉得这玩意贼好写啊(不到2k的线段树

#include<cstdio>
#include<algorithm>
#define lp p<<1
#define rp (p<<1)|1
#define MN 400000
using namespace std; int read_p,read_ca;
inline int read(){
read_p=;read_ca=getchar();
while(read_ca<''||read_ca>'') read_ca=getchar();
while(read_ca>=''&&read_ca<='') read_p=read_p*+read_ca-,read_ca=getchar();
return read_p;
}
int n,m,a[MN],b[MN],t[MN*][][],C[][],Mavis[][],mmh=;
const int MOD=1e9+;
inline void M(int &x){while(x>=MOD)x-=MOD;while(x<)x+=MOD;}
bool cmp(int x,int y){return a[x]>a[y];}
void cc(int a[][],int b[][],int c[][]){
int i,j,k;
for (i=;i<;i++)
for (j=;j<;j++)
for (C[i][j]=,k=;k<;k++) C[i][j]=(1LL*a[i][k]*b[k][j]+C[i][j])%MOD; for (i=;i<;i++)
for (j=;j<;j++) c[i][j]=C[i][j];
}
void build(int p,int l,int r){
if (l==r){
t[p][][]=t[p][][]=t[p][][]=;t[p][][]=;
return;
}
int mid=l+r>>;
build(lp,l,mid);build(rp,mid+,r);
cc(t[lp],t[rp],t[p]);
}
void ask(int p,int l,int r,int k){
if (k<l) return;
if (r<=k){
cc(Mavis,t[p],Mavis);
return;
}
int mid=l+r>>;
ask(lp,l,mid,k);ask(rp,mid+,r,k);
}
void cg(int p,int l,int r,int k){
if (l==r){
t[p][][]=t[p][][]=t[p][][]=;t[p][][]=;
return;
}
int mid=l+r>>;
if (k<=mid) cg(lp,l,mid,k);else cg(rp,mid+,r,k);
cc(t[lp],t[rp],t[p]);
}
int main(){
n=read();
for (int i=;i<=n;i++) a[i]=read(),b[i]=i;
sort(b+,b++n,cmp);
for (int i=;i<=n;i++) a[b[i]]=i; build(,,n);
for (int i=;i<=n;i++){
Mavis[][]=Mavis[][]=;Mavis[][]=Mavis[][]=;
if (a[i]-) ask(,,n,a[i]-);
M(mmh+=Mavis[][]);M(mmh+=Mavis[][]);
cg(,,n,a[i]);
}
M(mmh-=n);
printf("%d\n",mmh);
}

城乡联谊胡策会糊厕R3的更多相关文章

  1. 弱省胡策 Magic

    弱省胡策 Magic 求\(n\)个点\(n\)的条边的简单联通图的个数. 毒瘤,还要写高精. 我们枚举环的大小\(k\),\(\displaystyle ans=\sum_{k=3}^nC_n^k ...

  2. 【弱省胡策】Round #5 Count

    [弱省胡策]Round #5 Count 太神仙了. \(DP\)做法 设\(f_{n,m,d,k}\)表示\(n*m\)的矩阵,填入第\(k\)个颜色,并且第\(k\)个颜色最少的一列上有\(d\) ...

  3. 【ContestHunter】【弱省胡策】【Round0】(A)&【Round1】(B)

    DP+容斥原理or补集转化?/KD-Tree 唔……突然发现最早打的两场(打的最烂的两场)没有写记录……(太烂所以不忍记录了吗... 还是把搞出来了的两道题记录一下吧= =勉强算弥补一下缺憾…… Ro ...

  4. luoguP3769 [CH弱省胡策R2]TATT

    luoguP3769 [CH弱省胡策R2]TATT PS:做这题前先切掉 P4148简单题,对于本人这样的juruo更助于理解,当然dalao就当练练手吧 题目大意: 现在有n个四维空间中的点,请求出 ...

  5. 【ContestHunter】【弱省胡策】【Round3】(C)

    容斥原理+Fib Orz HE的神犇们 蒟蒻只能改出来第三题……实在太弱 官方题解:http://pan.baidu.com/s/1o6MdtQq fib的神奇性质……还有解密a[i]的过程……这里就 ...

  6. 【ContestHunter】【弱省胡策】【Round2】

    官方题解:http://wyfcyx.is-programmer.com/posts/95490.html A 目前只会30分的暴力……DP好像很神的样子0.0(听说可以多次随机强行算? //Roun ...

  7. 【弱省胡策】Round #5 Construct 解题报告

    这个题是传说中的 Hack 狂魔 qmqmqm 出的构造题.当然要神. 这个题的本质实际上就是构造一个图,然后使得任意两点间都有长度为 $k$ 的路径相连,然后对于任意的 $i < k$,都存在 ...

  8. 【弱省胡策】Round #5 Handle 解题报告

    这个题是我出的 sb 题. 首先,我们可以得到: $$A_i = \sum_{j=i}^{n}{j\choose i}(-1)^{i+j}B_j$$ 我们先假设是对的,然后我们把这个关系带进来,有: ...

  9. 【弱省胡策】Round #6 String 解题报告

    感觉这个题好神啊. 首先我们只管 $a = b$ 的情况,那么我们自然就可以把这个串对 $a$ 取模,然后用 KMP 求出能弄出几个其他的 B 串. 具体就是把串先倍长,然后倒过来,然后求 $Next ...

随机推荐

  1. 学习Lua setmetatable Lua 元表

    Lua 元表(Metatable) 在 Lua table 中我们可以访问对应的key来得到value值,但是却无法对两个 table 进行操作. 个人理解,这个相当于其他语言的继承,是把这个类的方法 ...

  2. 记录maven的一些命令

    为了方便后面找资料更快,记录下(不定期更新): maven官网:http://maven.apache.org/plugins/ mvn package打包 mvn package -DskipTes ...

  3. java随机生成验证码

    package com.yuyuchen.util; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; im ...

  4. Func和Action委托简单用法

    Func和Action类是特殊的类型,它们允许你在不必指定自定义委托类型的情况下,去使用委托.在整个.NET框架中都可以使用它们.例如,在我们考察并行计算时,你也会看到这两个类的示例. 上面一段文字是 ...

  5. websocket教程(一) 非常有趣的理解websocket

    一.websocket与http WebSocket是HTML5出的东西(协议),也就是说HTTP协议没有变化,或者说没关系,但HTTP是不支持持久连接的(长连接,循环连接的不算) 首先HTTP有 1 ...

  6. Java中静态代码块、构造代码块、构造函数、普通代码块

    在Java中,静态代码块.构造代码块.构造函数.普通代码块的执行顺序是一个笔试的考点,通过这篇文章希望大家能彻底了解它们之间的执行顺序. 1.静态代码块 ①.格式 在java类中(方法中不能存在静态代 ...

  7. 鸟哥的linux私房菜学习-(五)Linux系统的在线求助man page与info page

    1.man page man是manual(操作说明)的简写啦!只要下达:『man date』 马上就会有清楚的说明出现在你面前喔!如下所示: 进入man命令的功能后,你可以按下『空格键』往下翻页,可 ...

  8. Python并发实践_03_并发实战之一

    16S数据质控流程,一次下机lane包括很多的项目,每个项目有独立的合同号,一个项目可能包含16S或者ITS两种,通过一个完整的pipeline,将上游拆分好的数据全部整理成可以直接分析的数据.原本这 ...

  9. ASP.NET MVC 5使用Swagger生成API文档

    一.安装 新建一个没有身份验证的mvc项目 - SwaggerMvc5Demo,然后添加一个名为Remote(自定义)且包含基础读写(不想手写)的ApiController   开源地址:https: ...

  10. java基础之关键字static

        在java当中有很多关键字,static便是其中一个,它很普通但我们经常需要运用到它,所以要了解static是非常有必要的.   鉴于本人知识结构有限,若有错误忘不吝赐教,甚为感谢.   一. ...