期望得分:100+100+0=200

实际得分:

坐标的每一位不是0就是1,所以答案就是

C(n,k)

#include<cstdio>
#include<iostream> using namespace std; const int mod=1e9+; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int Pow(int a,int b)
{
int res=;
for(;b;a=1LL*a*a%mod,b>>=)
if(b&) res=1LL*res*a%mod;
return res;
} int main()
{
freopen("cube.in","r",stdin);
freopen("cube.out","w",stdout);
int n,k;
read(n); read(k);
int ans=;
for(int i=;i<=k;i++)
ans=1LL*ans*Pow(i,mod-)%mod*(n-i+)%mod;
cout<<ans;
}

货物一定是走在最大生成树上

如果按限重从大到小加边,那么一个联通块只需要有一个仓库

并查集维护即可

考场代码写的有点儿乱

#include<algorithm>
#include<iostream>
#include<cstdio> using namespace std; #define N 100001 int n,m; int fa[N];
bool cal[N]; int ans[N],tmp[N]; bool vis[N]; struct node
{
int u,v,lim;
bool use;
}e[N]; struct query
{
int id,w;
}a[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} bool cmp(node p,node q) { return p.lim>q.lim; } bool cmp2(query p,query q) { return p.w>q.w; } bool cmp3(node p,node q)
{
if(p.use!=q.use) return p.use>q.use;
return p.lim>q.lim;
} int find(int i) { return fa[i]==i ? i : fa[i]=find(fa[i]); } void MST()
{
for(int i=;i<=n;i++) fa[i]=i;
int tot=,i=,u,v;
while(tot!=n- && i<m)
{
i++;
u=find(e[i].u); v=find(e[i].v);
if(u==v) continue;
tot++; e[i].use=true;
fa[u]=v;
}
} int main()
{
freopen("warehouse.in","r",stdin);
freopen("warehouse.out","w",stdout);
int q;
read(n); read(m); read(q);
for(int i=;i<=m;i++) read(e[i].u),read(e[i].v),read(e[i].lim);
sort(e+,e+m+,cmp);
for(int i=;i<=q;i++) read(a[i].w),a[i].id=i;
sort(a+,a+q+,cmp2);
MST();
sort(e+,e+m+,cmp3);
for(int i=;i<=n;i++) fa[i]=i;
int ne=,nq=; int sum=n;
while(ne<=m)
{
if(!e[ne].use) break;
while(ne<=m && e[ne].lim>=a[nq].w)
{
if(find(e[ne].u)==find(e[ne].v))
{
ne++;
continue;
}
fa[find(e[ne].u)]=find(e[ne].v);
sum--;
ne++;
}
ans[a[nq].id]=sum;
nq++;
}
for(int i=nq;i<=q;i++) ans[a[i].id]=sum;
for(int i=;i<=q;i++) cout<<ans[i]<<'\n';
}

答案=原词典单词数+前缀后缀拼接单词数

统计前缀和后缀 拼接的单词:

一个基本错误思路:

如果有s1个长为l1 的前缀,有s2个长为l2的后缀,那么 他们对长为l1+l2 的单词的贡献为 s1*s2

错因:有可能会重复计数

例:

有单词 abc   bcd

那么合法单词abcd 会计算3次:

a+bcd   ab+cd   abc+d

所以对于每个合法的单词,强行规定一个分离位置,来保证一个单词只会被计算一次

规定的分离位置:

若单词长为i的前缀是词典中单词的前缀,长为i+1的前缀不是词典中单词的前缀

那么i就是单词的分离位置

即这个单词是由前面长为i的前缀 和 i后面的后缀 拼接而成

在这个不会算重的思路的基础上

设f[i][j] 表示 原词典单词中 长度为i的前缀,再加1个字母j就不是前缀的 前缀数量

g[i][j] 表示 原词典单词中 长为i的后缀,第1个字母是j的 后缀数量

这两个数组在 正序和倒序 trie树上dfs即可解决

那么长为 i+k 的 前缀后缀 拼接单词数量 = Σ f[i][j]*g[k][j]   j∈[0,26)

但思路仍然还有一个bug:

长为len 的 单词 的所有前缀 都是词典中单词的前缀

例:

词典中单词 cool   o

那么 co 是一个长为2的合法单词

但是co按上述方法找不到分离位置

对于这种单词,我们强制规定 最后两个字母之间为分离位置

注意:这种单词还要满足 不是原词典中的单词,后缀非空 两个条件

所以 设t[i][j] 表示 长为i的前缀,最后一个字母是j 且 不是词典中单词的数量

注意这里不要把长为1的前缀统计进去

如果 g[1][j] 那么 长为i的合法单词 就可以累计 t[i][j]

#include<cstdio>
#include<cstring>
#include<algorithm> #define N 10001
#define L 51 using namespace std; const int mod=1e9+; char s[L]; int ans[]; int f[L][],g[L][],t[L][]; struct TRIE
{
int trie[N*L][],id; int endd[N*L]; void insert(int len)
{
int now=;
for(int i=;i<=len;i++)
{
if(!trie[now][s[i]-'a']) trie[now][s[i]-'a']=++id;
now=trie[now][s[i]-'a'];
}
endd[now]++;
} void dfs(int x,int dep)
{
for(int i=;i<;++i)
{
if(x && !trie[x][i]) f[dep][i]++;
if(x && trie[x][i] && !endd[trie[x][i]]) t[dep+][i]++;
if(trie[x][i]) dfs(trie[x][i],dep+);
}
} void dfs2(int x,int dep)
{
for(int i=;i<;++i)
if(trie[x][i]) g[dep+][i]++,dfs2(trie[x][i],dep+);
} }t1,t2; int main()
{
freopen("word.in","r",stdin);
freopen("word.out","w",stdout);
int n,q,len;
scanf("%d%d",&n,&q);
for(int i=;i<=n;i++)
{
scanf("%s",s+);
len=strlen(s+);
t1.insert(len);
reverse(s+,s+len+);
t2.insert(len);
ans[len]++;
}
t1.dfs(,);
t2.dfs2(,);
for(int i=;i<=;++i)
for(int j=;j<;++j)
if(g[][j]) ans[i]=(ans[i]+t[i][j])%mod;
for(int i=;i<=;++i)
for(int k=;k<=;++k)
for(int j=;j<;++j)
ans[i+k]=(1LL*ans[i+k]+f[i][j]*g[k][j]%mod)%mod;
int x;
while(q--)
{
scanf("%d",&x);
printf("%d\n",ans[x]);
}
}

2017 清北济南考前刷题Day 5 morning的更多相关文章

  1. 2017 清北济南考前刷题Day 7 afternoon

    期望得分:100+100+30=230 实际得分:100+100+30=230 1. 三向城 题目描述 三向城是一个巨大的城市,之所以叫这个名字,是因为城市中遍布着数不尽的三岔路口.(来自取名力为0的 ...

  2. 2017 清北济南考前刷题Day 1 afternoon

    期望得分:80+30+70=180 实际得分:10+30+70=110 T1 水题(water) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK出了道水 ...

  3. 2017 清北济南考前刷题Day 3 morning

    实际得分:100+0+0=100 T1 右上角是必败态,然后推下去 发现同行全是必胜态或全是必败态,不同行必胜必败交叉 列同行 所以n,m 只要有一个是偶数,先手必胜 #include<cstd ...

  4. 2017 清北济南考前刷题Day 3 afternoon

    期望得分:100+40+100=240 实际得分:100+40+100=240 将每个联通块的贡献乘起来就是答案 如果一个联通块的边数>点数 ,那么无解 如果边数=点数,那么贡献是 2 如果边数 ...

  5. 2017 清北济南考前刷题Day 4 afternoon

    期望得分:30+50+30=110 实际得分:40+0+0=40 并查集合并再次写炸... 模拟更相减损术的过程 更相减损术,差一定比被减数小,当被减数=减数时,停止 对于同一个减数来说,会被减 第1 ...

  6. 2017 清北济南考前刷题Day 7 morning

    期望得分:100+50+20=170 实际得分:10+50+20=80 1. 纸牌 题目描述 在桌面上放着n张纸牌,每张纸牌有两面,每面都写着一个非负整数.你的邪王真眼可以看到所有牌朝上的一面和朝下的 ...

  7. 2017 清北济南考前刷题Day 6 afternoon

    期望得分:100+100+30=230 实际得分: 正解: 枚举最高的位,这一位m是1但实际用了0 然后剩余的低位肯定是 正数就用1,负数用0 考场思路:数位DP #include<cstdio ...

  8. 2017 清北济南考前刷题Day 6 morning

    T1 贪心 10 元先找5元 20元 先找10+5,再找3张5 #include<cstdio> using namespace std; int m5,m10,m20; int main ...

  9. 2017 清北济南考前刷题Day 5 afternoon

    期望得分:100+100+30=230 实际得分:0+0+0=30 T1 直接模拟 #include<cstdio> #include<iostream> using name ...

随机推荐

  1. Java实现小学四则运算练习

     Github项目地址:https://github.com/feser-xuan/Arithmetic.git 1.需求分析 软件基本功能要求如下: 程序可接收一个输入参数n,然后随机产生n道加减乘 ...

  2. vSphere下安装Hyper-V

    在vSphere 5.5中默认是无法嵌套安装Hyper-V的,必须在vSphere中稍作修改. 1. 勾选这两个选项,如果是灰色,请升级虚拟机版本至最新: 2. 在配置文件中手动加入这一行参数: 3. ...

  3. 计算机网络【4】—— TCP和UDP的区别

    一.TCP/UDP优点和缺点 TCP的优点: 可靠,稳定 TCP的可靠体现在TCP在传递数据之前,会有三次握手来建立连接,而且在数据传递时,有确认.窗口.重传.拥塞控制机制,在数据传完后,还会断开连接 ...

  4. Java多线程(四) —— 线程并发库之Atomic

    一.从原子操作开始 从相对简单的Atomic入手(java.util.concurrent是基于Queue的并发包,而Queue,很多情况下使用到了Atomic操作,因此首先从这里开始). 很多情况下 ...

  5. echarts 地图 离线json包分享

    最近,项目中需要用到地图,由于项目的特殊性,只能使用内网获取数据. 然而,echarts官网上的离线地图包(http://echarts.baidu.com/download-map.html)早在一 ...

  6. 如何认识TOS----DSCP 对照表

    如何认识TOS----DSCP 对照表 最近有遇到项目中对FortiGate设置TOS的策略路由的问题,其实这问题较为简单,但是由于大家对TOS-DSCP概念不熟悉造成的,所以感觉比较难,现在不同厂商 ...

  7. 洛谷 P2805 [NOI2009]植物大战僵尸 解题报告

    P2805 [NOI2009] 植物大战僵尸 题目描述 Plants vs. Zombies(PVZ)是最近十分风靡的一款小游戏.Plants(植物)和Zombies(僵尸)是游戏的主角,其中Plan ...

  8. 【bzoj4540】 Hnoi2016—序列

    http://www.lydsy.com/JudgeOnline/problem.php?id=4540 (题目链接) 题意 给出$n$个数的序列,$m$个询问,每次询问一段区间$[l,r]$,问$[ ...

  9. Ecshop 2.x_3.x SQL注入和代码执行漏洞复现和分析

    0x00 前言 问题发生在user.php的的显示函数,模版变量可控,导致注入,配合注入可达到远程代码执行 0x01 漏洞分析 1.SQL注入 先看user.php的$ back_act变量来源于HT ...

  10. linux内核分析 第五周读书笔记

    第18章 调试 内核调试的难度大于用户级 一.准备开始 开始之前需要的是: 一个行为可靠且定义明确的bug 一个隐匿bug的内核版本 相关内核代码的知识和运气 想要成功的调试,取决于能不能将这些bug ...