卡map还行.....手写hash表即可。

我一开始以为这个k会变......在sam上想各种奇技淫巧。

k不变就是问一段区间有多少对长度为k的子串相同。

然后hash把子串转化为数字,就是区间有多少对相同数字。直接莫队即可。

 #include <bits/stdc++.h>

 inline void read(int &x) {
x = ;
char c = getchar();
while(c < '' || c > '') c = getchar();
while(c >= '' && c <= '') {
x = x * + c - ;
c = getchar();
}
return;
} typedef long long LL;
typedef unsigned long long uLL;
const int N = ;
const uLL B = ; uLL h[N], pw[N];
std::map<uLL, int> mp;
int n, k, val[N], fr[N], bin[N];
char str[N];
LL ans[N], Ans; namespace Map {
const int mod = ;
struct Edge {
uLL val;
int num, nex;
}edge[N]; int tp;
int e[mod], num;
inline int insert(uLL v) {
int x = v % mod;
for(int i = e[x]; i; i = edge[i].nex) {
if(edge[i].val == v) return edge[i].num;
}
edge[++tp].val = v;
edge[tp].num = ++num;
edge[tp].nex = e[x];
e[x] = tp;
return num;
}
} struct Ask {
int l, r, id;
inline bool operator <(const Ask &w) const {
if(fr[l] != fr[w.l]) return l < w.l;
return r < w.r;
}
}ask[N]; inline uLL Hash(int l, int r) {
return h[r] - h[l - ] * pw[r - l + ];
} inline void getHash() {
pw[] = ;
for(register int i = ; i <= n; i++) {
pw[i] = B * pw[i - ];
h[i] = h[i - ] * B + str[i];
}
for(register int i = ; i + k - <= n; i++) {
uLL t = Hash(i, i + k - );
//printf("i = %d t = %llu \n", i, t);
val[i] = Map::insert(t);
//printf("val %d = %d \n", i, val[i]);
}
return;
} inline void add(int x) {
Ans += bin[val[x]];
bin[val[x]]++;
return;
} inline void del(int x) {
bin[val[x]]--;
Ans -= bin[val[x]];
return;
} int main() {
int m;
read(n); read(m); read(k);
scanf("%s", str + );
int T = (double)n / sqrt(m);
for(register int i = ; i <= m; i++) {
read(ask[i].l); read(ask[i].r);
ask[i].r = std::min(ask[i].r, n - k + );
ask[i].id = i;
}
for(register int i = ; i <= n; i++) fr[i] = (i - ) / T + ;
std::sort(ask + , ask + m + );
getHash(); int l = , r = ; bin[val[]] = ;
for(register int i = ; i <= m; i++) {
if(ask[i].l >= ask[i].r) {
ans[ask[i].id] = ;
continue;
}
while(ask[i].l < l) {
add(--l);
}
while(r < ask[i].r) {
add(++r);
}
while(l < ask[i].l) {
del(l++);
}
while(ask[i].r < r) {
del(r--);
}
ans[ask[i].id] = Ans;
}
for(register int i = ; i <= m; i++) printf("%lld\n", ans[i]);
return ;
}

AC代码

洛谷P5112 FZOUTSY的更多相关文章

  1. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  2. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

  3. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

  4. 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP

    题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...

  5. 洛谷P1710 地铁涨价

    P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交  讨论  题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...

  6. 洛谷P1371 NOI元丹

    P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交  讨论  题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...

  7. 洛谷P1538迎春舞会之数字舞蹈

    题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...

  8. 洛谷八月月赛Round1凄惨记

    个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...

  9. 洛谷 P1379 八数码难题 Label:判重&&bfs

    特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...

随机推荐

  1. day 7-20 视图,触发器,事务

    一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的 ...

  2. logback框架之——日志分割所带来的潜在问题

    源码: logback-test.xml文件如下,有2个需要我们重点关注的参数: fileNamePattern:这里的日志文件名变动的部分是年月日时,外加1个文件分割自增变量,警告,年月日时的数值依 ...

  3. Centos6.8 安装nginx

    1.安装相关依赖 (1)yum install gcc 备注:可以通过gcc -v 查看版本信息,来确定是否安装过. (2)yum install pcre-devel (3)yum install ...

  4. loadrunner 事务、同步点和思考时间

    事务 在LoadRunner里,我们定义事务主要是为了度量服务器的性能.每个事务度量服务器响应指定的Vuser请求所有的时间,这些请求可以是简单任务,也可以是复杂任务. 要度量事务,需要插入Vuser ...

  5. Reversing-x64Elf-100

    一道很简单的小题 作为python小白这道题主要是学习了一点python知识...... 可以看出来 sub_4006FD 这个函数是用来判断输入密码是否正确的 我们看一下它的伪代码: signed ...

  6. Lodop打印html数字间隔不一致

    在font-size属性控制数字大小的时候,可能会出现数字间隔有问题,间隔不一致,可尝试用其他字体大小试试,一般字体越小,越可能出现问题. 如图,前两个打印项都是form1,样式一个是style1,一 ...

  7. Jenkins+PowerShell持续集成环境搭建(二)控制台项目

    1. 新建一个名字为HelloWorld.Console的Freesyle项目: 2. 配置源码管理: 3. 编译配置: 版本:选择MSBuild4 文件:D:\CI\Config\HelloWorl ...

  8. sed命令参数之-r -i

    对于初学linux的朋友来说,能记住命令附带的一大帮参数就以及非常不容易了.好不容易把该用的参数都想全了.sed -irns 后面一大片脚本 ,一执行出错了 what!!!! 创建一下测试环境 hea ...

  9. .net core compatibility windows & windows compatible Linux

    Who is this package for? This package is meant for developers that need to port existing .NET Framew ...

  10. 使用java代码批量删除新浪微博

    首先开骂,新浪微博@#@!,不经我同意就转发各种微博,制造垃圾,还不提供微博批量删除功能,摆明了的流氓行为,可耻可恨,遭人唾弃! SSLClient.java import org.apache.ht ...