博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
A Game with Colored Balls
阅读量:6267 次
发布时间:2019-06-22

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

  • 题意:
    给一个长度为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
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;}

转载地址:http://lgbpa.baihongyu.com/

你可能感兴趣的文章
iOS使用宏写单例
查看>>
Isotig & cDNA & gene structure & alternative splicing & gene loci & 表达谱
查看>>
3、Cocos2dx 3.0游戏开发找小三之搭建开发环境
查看>>
携程Apollo(阿波罗)配置中心使用Google代码风格文件(在Eclipse使用Google代码风格)(配合阿里巴巴代码规约快速设置)...
查看>>
Hadoop(七)HDFS容错机制详解
查看>>
字符串中去除多余的空格保留一个(C#)
查看>>
Python随机字符串验证码
查看>>
SQL中 patindex函数的用法
查看>>
Vmware 虚拟机无法启动
查看>>
LeetCode: Partition List 解题报告
查看>>
如何查看Python对象的属性
查看>>
你所需要知道的一些git 的使用命令:历史
查看>>
mysql explain输出中type的取值说明
查看>>
iPhone开发之 - 苹果推送通知服务(APNs)编程
查看>>
linux下so动态库一些不为人知的秘密(上)
查看>>
文本框设置只读,后台可获取
查看>>
JAVA:URL之String组件
查看>>
架构,改善程序复用性的设计~目录(附核心原代码)
查看>>
逆向反汇编代码推算C++的局部变量
查看>>
100个推荐的图片/内容滑动条
查看>>