博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
codeforces 666C Codeword
阅读量:5338 次
发布时间:2019-06-15

本文共 2107 字,大约阅读时间需要 7 分钟。

codeforces 666C Codeword

题意

q个询问,一种询问是给你一个字符串,还有一种是问长度为n的,包含当前字符串为子序列的字符串有多少个。

题解

容易写出式子,但是不好化简。

观察一下可以知道q个询问的字符串长度也就根号种。

代码

#include
using namespace std;#define fi first#define se second#define mp make_pair#define pb push_back#define rep(i, a, b) for(int i=(a); i<(b); i++)#define sz(a) (int)a.size()#define de(a) cout << #a << " = " << a << endl#define dd(a) cout << #a << " = " << a << " "#define all(a) a.begin(), a.end()#define endl "\n"typedef long long ll;typedef pair
pii;typedef vector
vi;//---const int N = 101010, P = 1e9+7;int pw[N], jc[N], in[N], ans[N];vector
Q[N];inline int mul(int a, int b) { return a * 1ll * b % P;}inline int add(int a, int b) { int res = a+b; if(res >= P) res -= P; return res;}inline int kpow(int a, int b) { int res = 1; while(b) { if(b&1) res = mul(res, a); a = mul(a, a); b >>= 1; } return res;}inline void init() { pw[0] = 1; rep(i, 1, N) pw[i] = mul(pw[i-1], 25); jc[0] = 1; rep(i, 1, N) jc[i] = mul(jc[i-1], i); in[N-1] = kpow(jc[N-1], P-2); for(int i = N-2; ~i; --i) in[i] = mul(in[i+1], i+1);}inline int C(int n, int m) { if(n < m) return 0; return mul(jc[n], mul(in[m], in[n-m]));}int main() { std::ios::sync_with_stdio(false); std::cin.tie(0); init(); int n, m, q; string s; cin >> q >> s; m = sz(s); rep(i, 0, q) { int x; cin >> x; if(x == 1) { cin >> s; m = sz(s); } else { cin >> n; Q[m].pb(mp(n, i)); } } rep(m, 0, N) if(sz(Q[m])) { sort(all(Q[m])); int i = m, res = 1; for(auto t : Q[m]) { int n = t.fi; while(i < n) { ++i; res = mul(res, 26); res = add(res, mul(C(i-1, m-1), pw[i - m])); } ans[t.se] = n >= m ? res : 0; ++ans[t.se]; } } rep(i, 0, q) if(ans[i]) { cout << ans[i]-1 << endl; } return 0;}

转载于:https://www.cnblogs.com/wuyuanyuan/p/9247368.html

你可能感兴趣的文章
认证和授权(Authentication和Authorization)
查看>>
Mac上安装Tomcat
查看>>
CSS3中box-sizing的理解
查看>>
传统企业-全渠道营销解决方案-1
查看>>
Lucene全文检索
查看>>
awk工具-解析1
查看>>
推荐一款可以直接下载浏览器sources资源的Chrome插件
查看>>
CRM product UI里assignment block的显示隐藏逻辑
查看>>
展望未来,总结过去10年的程序员生涯,给程序员小弟弟小妹妹们的一些总结性忠告...
查看>>
AMH V4.5 – 基于AMH4.2的第三方开发版
查看>>
Mac下安装npm全局包提示权限不够
查看>>
Web.Config文件配置之配置Session变量的生命周期
查看>>
Java网络编程(读书笔记)
查看>>
mysql 中如何查找相同的数据
查看>>
mysql中的having
查看>>
mysql导入source注意点
查看>>
Python: 对于DataFrame.loc传入列表和传入元组输出区别的理解
查看>>
USACO / Sorting a Three-Valued Sequence (简单题,方法正确性待证)
查看>>
Android开发中 .9.png格式图形设计:
查看>>
Linux常见命令
查看>>