博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 4125 Moles 段树+KMP
阅读量:6156 次
发布时间:2019-06-21

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

意甲冠军:

特定n,

下面是一个1-n该装置。

下面的二进制字符串。

按给定的建立二叉树安排。

然后遍历树(根->左子树->根->右子树->根)

当遍历节点 如果右值为奇数入栈一个1,若为偶数入栈一个0

得到一个母串。

问母串中出现了几次子串。

思路:

先是建树得到母串。然后求子串个数就是裸的KMP。

建树就是找个规律,然后用线段树维护一下输入的排列

#include 
#include
#include
#include
using namespace std;#pragma comment(linker, "/STACK:1024000000,1024000000")typedef long long ll;#define lson l, mid, rt<<1#define rson mid+1, r, rt<<1|1template
inline bool rd(T &ret) { char c; int sgn; if(c=getchar(),c==EOF) return 0; while(c!='-'&&(c<'0'||c>'9')) c=getchar(); sgn=(c=='-')?-1:1; ret=(c=='-')?0:(c-'0'); while(c=getchar(),c>='0'&&c<='9') ret=ret*10+(c-'0'); ret*=sgn; return 1;}template
inline void pt(T x) { if (x <0) { putchar('-'); x = -x; } if(x>9) pt(x/10); putchar(x%10+'0');}//const int N = 600000+5;const int M = 70000+5;int mi[N<<2], pos[N];inline void up(int& fa, int& ls, int& rs) { if (ls>rs) fa = rs; else fa = ls;}void build(int l, int r, int rt) { if (l == r) { mi[rt] = pos[l]; } else { int mid = (l+r)>>1; build(lson); build(rson); up(mi[rt], mi[rt<<1], mi[rt<<1|1]); }}int query(int L, int R, int l, int r, int rt) { if (L<= l && r<=R) { return mi[rt]; } else { int mid = (l+r)>>1; if (L>mid) return query(L, R, rson); else if (R<=mid) return query(L, R, lson); else return min(query(L, mid, lson), query(mid+1, R, rson)); }}void update(int p, int v, int l, int r, int rt) { if (l == r) { mi[rt] = v; } else { int mid = (l+r)>>1; if (p <= mid) update(p, v, lson); else update(p, v, rson); up(mi[rt], mi[rt<<1], mi[rt<<1|1]); }}int T = 0, n, a[N], L[N], R[N];char s[M], ch[N*3];int nex[M], top;void dfs(int u, int l, int r) { update(u, n+1, 1, n, 1); int v = query(l, u, 1, n, 1); if (v != n+1) { L[u] = a[v]; dfs(a[v], l, u); } v = query(u, r, 1, n, 1); if (v != n+1) { R[u] = a[v]; dfs(a[v], u, r); }}void f(int u) { char c; if (u&1) c = '1'; else c = '0'; ch[top++] = c; if (L[u] != -1) { f(L[u]); ch[top++] = c; } if (R[u] != -1) { f(R[u]); ch[top++] = c; }}void work() { int v, len, idx, ans = 0; rd(n); for (int i = 1; i <= n; ++i) { rd(a[i]); pos[a[i]] = i; } build(1, n, 1); memset(L, -1, sizeof L); memset(R, -1, sizeof R); dfs(a[1], 1, n); // scanf("%s", s); len = strlen(s); nex[0] = nex[1] = 0; for (int i = 1; i < len; ++i) { int j = nex[i]; while (j && s[j] != s[i]) j = nex[j]; if (s[i] == s[j]) nex[i+1] = j+1; else nex[i+1] = 0; } // top = 0; f(a[1]); idx = 0; for (int i = 0; i < top; ++i) { while (idx && s[idx] != ch[i]) idx = nex[idx]; if (s[idx] == ch[i]) ++ idx; if (idx == len) { ++ ans; idx = nex[idx]; } } printf("Case #%d: %d\n", ++T, ans);}int main() { int cas; scanf("%d", &cas); while (cas-->0) work(); return 0;}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

你可能感兴趣的文章
Consul入门04 - Consul集群
查看>>
Electron初步【02】--第一个Electron App
查看>>
Mysql 架构及优化之-索引优化
查看>>
[LintCode] Simplify Path [字符串操作]
查看>>
exadata磁盘组无法mount恢复---惜分飞
查看>>
浅入浅出Typescript Decorators
查看>>
MongoDB 命令速查表
查看>>
IDC 2018可穿戴市场报告:耳戴式设备占比四分之一,成“新宠”
查看>>
计算二叉树叶子节点的数目
查看>>
Tensorflow源码解析6 -- TensorFlow本地运行时
查看>>
Django 表单
查看>>
扬尘监测系统_工地扬尘监测_工地扬尘监测解决方案
查看>>
Oracle11gR2在9x8hk..Windows18669144449 命名进入Oracle
查看>>
Chrome 被曝 0day 漏洞,可让黑客获取用户数据
查看>>
Django 模板
查看>>
gitbook
查看>>
约三分之二的 DDoS 攻击指向通信服务提供商
查看>>
怎样把开启的服务放到后台?
查看>>
LAMP-fpm
查看>>
gradle研究
查看>>