题目链接

  • 题意:

    给一个长度为n的字符串,每次删除字母同样切连续的串,假设有多个,删除最左边的、最长的串。每次删除输出串的字母,每一个字母的下标(1-n)

    N (1 ≤ N ≤
    106),串仅仅包含red (‘R’),
    green (‘G’) or blue (‘B’)
  • 分析:

    题目比較麻烦,分析一下须要的任务:

    1、每次找到最长串——优先队列

    2、删除最长串后,须要合并两側的串(假设字母同样)——加Hash的链表,set(超时)

    3、每次删除须要知道这一个区间的下标都是谁——加Hash的链表,set(超时)
C++通过,G++超时……
const int MAXN = 1100000;

struct Node
{
int pos, len;
char val;
Node *nxt, *pre;
Node (int p = 0, int n = 0, char v = 0) : pos(p), len(n), val(v) {}
bool operator< (const Node& rhs) const
{
return pos < rhs.pos;
}
void erase()
{
pre->nxt = nxt;
nxt->pre = pre;
}
} nd[MAXN], pt, fst, lst;
int tot; struct HeapNode
{
int val, pos;
HeapNode (int v = 0, int p = 0) : val(v), pos(p) {}
bool operator< (const HeapNode& rhs) const
{
if (val != rhs.val)
return val < rhs.val;
return pos > rhs.pos;
}
} vt; priority_queue<HeapNode> q;
char ipt[MAXN];
bool vis[MAXN];
Node* to[MAXN], *pit, *pl, *pr;
int nxt[MAXN], pre[MAXN]; void init(int n)
{
REP(i, n)
{
nxt[i] = i + 1;
if (i)
pre[i] = i - 1;
}
}
void erase(int l, int r)
{
int p = pre[l], n = nxt[r];
nxt[p] = n;
pre[n] = p;
} int main()
{
while (~RS(ipt))
{
fst.val = -1; fst.nxt = &lst; fst.pre = NULL;
lst.val = -2; lst.pre = &fst; lst.nxt = NULL;
CLR(vis, false);
while (!q.empty())
q.pop();
tot = 0;
int len = strlen(ipt);
init(len + 2); nd[tot++] = Node(1, 1, ipt[0]);
FF(i, 1, len)
{
if (ipt[i] == nd[tot - 1].val)
nd[tot - 1].len++;
else
{
nd[tot].pos = i + 1;
nd[tot].len = 1;
nd[tot].val = ipt[i];
tot++;
}
}
fst.nxt = &nd[0]; nd[0].pre = &fst;
lst.pre = &nd[tot - 1]; nd[tot - 1].nxt = &lst;
REP(i, tot)
{
if (i != 0)
nd[i].pre = &nd[i - 1];
if (i != tot - 1)
nd[i].nxt = &nd[i + 1];
to[nd[i].pos] = &nd[i];
q.push(HeapNode(nd[i].len, nd[i].pos));
}
while (!q.empty())
{
vt = q.top();
q.pop();
if (vt.val == 1)
break;
if (vis[vt.pos])
continue;
pt.pos = vt.pos;
pit = to[vt.pos]; int idx = vt.pos;
printf("%c", ipt[vt.pos - 1]);
REP(i, vt.val)
{
printf(" %d", idx);
erase(idx, idx);
idx = nxt[pre[idx]];
}
puts(""); pl = pit->pre; pr = pit->nxt;
if (pl->val == pr->val)
{
pl->len += pr->len; vis[pr->pos] = true;
pr->erase(); q.push(HeapNode(pl->len, pl->pos));
}
vis[vt.pos] = true;
pit->erase();
}
}
return 0;
}

A Game with Colored Balls的更多相关文章

  1. Codeforces554 C Kyoya and Colored Balls

    C. Kyoya and Colored Balls Time Limit: 2000ms Memory Limit: 262144KB 64-bit integer IO format: %I64d ...

  2. codeforces 553A . Kyoya and Colored Balls 组合数学

    Kyoya Ootori has a bag with n colored balls that are colored with k different colors. The colors are ...

  3. Codeforces Round #309 (Div. 2) C. Kyoya and Colored Balls 排列组合

    C. Kyoya and Colored Balls Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contes ...

  4. Kyoya and Colored Balls(组合数)

    Kyoya and Colored Balls time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  5. C. Kyoya and Colored Balls(Codeforces Round #309 (Div. 2))

    C. Kyoya and Colored Balls Kyoya Ootori has a bag with n colored balls that are colored with k diffe ...

  6. 554C - Kyoya and Colored Balls

    554C - Kyoya and Colored Balls 思路:组合数,用乘法逆元求. 代码: #include<bits/stdc++.h> using namespace std; ...

  7. Codeforces Round #309 (Div. 2) C. Kyoya and Colored Balls

    Kyoya Ootori has a bag with n colored balls that are colored with k different colors. The colors are ...

  8. Codeforces554C:Kyoya and Colored Balls(组合数学+费马小定理)

    Kyoya Ootori has a bag with n colored balls that are colored with k different colors. The colors are ...

  9. codeforces 553A A. Kyoya and Colored Balls(组合数学+dp)

    题目链接: A. Kyoya and Colored Balls time limit per test 2 seconds memory limit per test 256 megabytes i ...

  10. codeforces 553 A Kyoya and Colored Balls

    这个题.比赛的时候一直在往dp的方向想,可是总有一个组合数学的部分没办法求, 纯粹组合数学撸,也想不到办法-- 事实上,非常显然.. 从后往前推,把第k种颜色放在最后一个,剩下的k球.还有C(剩余的位 ...

随机推荐

  1. 【POJ 2010 Moo University-Financial Aid】优先级队列

    题目链接:http://poj.org/problem?id=2010 题意:C只牛犊,各有自己的分数score和申请的补助aid,现要选出N只(N为奇数),使得其aid的总和不超过F,且按score ...

  2. [置顶] 九度笔记之 1434:今年暑假不AC

    题目1434:今年暑假不AC 时间限制:1 秒 内存限制:128 兆 特殊判题:否 提交:307 解决:180 题目描述: “今年暑假不AC?”“是的.”“那你干什么呢?”“看世界杯呀,笨蛋!”“@# ...

  3. OpenRisc-45-or1200的ID模块分析

    引言 之前,我们分析了or1200流水线的整体结构,也分析了流水线中IF级,EX级,本小节我们来分析ID(insn decode)级的一些细节. 1,基础 or1200的pipeline的ID阶段包含 ...

  4. 今日成长笔记2016-11-18 - 关于java开发

    好久没有写今日成长笔记了,要记得上一次写笔记还是2016-09-05,今天心血来潮,写一写最近发生在自己身上的事情,以后我要坚持每天写日记.我承认自己身上的确或多或少的存在不足,现在把它们抛出来,并记 ...

  5. java转换字符串编码格式 (解码错误,重新解码)

    字符集概念:规定了某个文字对应的二进制数字存放方式(编码)和某串二进制数值代表了哪个文字(解码)的转换关系. 我们在计算机屏幕上看到的是实体化的文字,而在计算机存储介质中存放的实际是二进制的比特流. ...

  6. IOS 下雪动画

    #define SNOW_IMAGENAME @"snow" #define IMAGE_X arc4random()%(int)Main_Screen_Width #define ...

  7. 认识SVN

    TortoiseSVN 是 Subversion 版本控制系统的一个免费开源客户端,可以超越时间的管理文件和目录.文件保存在中央版本库,除了能记住文件和目录的每次修改以外,版本库非常像普通的文件 服务 ...

  8. Capture the Flag(模拟)

    Capture the Flag Time Limit: 2 Seconds      Memory Limit: 65536 KB      Special Judge In computer se ...

  9. hdu 3954 Level up(线段树)

    题目链接:hdu 3954 Level up 题目大意:N个英雄,M个等级,初始等级为1,给定每一个等级须要的经验值,Q次操作,操作分两种,W l r x:表示l~r之间的英雄每一个人杀了x个怪物:Q ...

  10. LR实战之Discuz开源论坛——安装及简介

    想了很久,也许是因为这段时间特别闲,从毕业到现在,我的测试职业生涯也近两年了,发现自己越来越喜欢测试领域,也越来越偏向测试开发了,作为一名专业的测试人员,不得不要学习性能测试,而使用LoadRunne ...