1、题目大意:就是给你一个栈,有一些操作,向栈加入空集,把栈顶的元素复制一遍再加入栈,求栈顶两元素的并集,交集

还有栈的第一个元素和栈顶(将栈顶压缩成一个元素)

2、分析:这个其实不是用hash做的,是用系统地一堆函数做的。。

我用hash做的,其实就是暴力的hash,用ULL,用了一堆的STL。。。。不要去重,然后RKhash的长度记得取模

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <vector>
#include <stack>
using namespace std;
#define ULL unsigned long long
#define ygorz pair<ULL, int>
stack<vector<ygorz> > st;
char str[20];
ygorz qaq[200000];
ULL power[200000];
int main() {
    int n;
    scanf("%d", &n);
    power[0] = 1;
    for (int i = 1; i <= 199900; i++) power[i] = power[i - 1] * 107;
    for (int i = 1; i <= n; i++) {
        scanf("%s", str);
        if (str[0] == 'P') {
            vector<ygorz> a;
            a.clear();
            st.push(a);
        }
        else if (str[0] == 'D') {
            st.push(st.top());
        }
        else if (str[0] == 'U') {
            vector<ygorz> a = st.top(); st.pop();
            vector<ygorz> b = st.top(); st.pop();
            int u = 0, v = 0;
            int wt = 0;
            while (u < a.size() || v < b.size()) {
                if (u == a.size()) {
                    qaq[++wt] = b[v];
                    v++;
                }
                else if (v == b.size()) {
                    qaq[++wt] = a[u];
                    u++;
                }
                else {
                    if (a[u] < b[v]) {
                        qaq[++wt] = a[u];
                        u++;
                    }
                    else if (a[u] > b[v]) {
                        qaq[++wt] = b[v];
                        v++;
                    }
                    else {
                        qaq[++wt] = a[u];
                        u++; v++;
                    }
                }
            }
            vector<ygorz> c;
            if(wt){
                c.clear();
                for (int i = 1; i <= wt; i++){
                    c.push_back(qaq[i]);
                }
            }
            st.push(c);
        }
        else if (str[0] == 'I') {
            vector<ygorz> a = st.top(); st.pop();
            vector<ygorz> b = st.top(); st.pop();
            int u = 0, v = 0;
            /*for (; u < a.size(); u++)
            {
                for (; v < b.size()&&b[v] < a[u]; v++);
                if (v < b.size()&&a[u] == b[v]) c.push_back(a[u]);
            }
            */
            int wt = 0;
            while (u < a.size() || v < b.size()) {
                if (u == a.size()) {
                // qaq[++wt] = b[v];
                 v++;
                }
                else if (v == b.size()) {
                // qaq[++wt] = a[u];
                 u++;
                }
                else {
                    if (a[u] < b[v]) {
            //         qaq[++wt] = a[u];
                     u++;
                    }
                    else if (a[u] > b[v]) {
            //         qaq[++wt] = b[v];
                     v++;
                    }
                    else {
                        qaq[++wt] = a[u];
                        u++; v++;
                    }
                }
            }
            vector<ygorz> c;
            if(wt){
                c.clear();
                qaq[wt + 1].first = -1;
                for (int i = 1; i <= wt; i++){
                    c.push_back(qaq[i]);
                }
            }
            st.push(c);
        }
        else {
            ULL hash = 5;
            int ll = 2;
            vector<ygorz> a = st.top(); st.pop();
            vector<ygorz> b = st.top(); st.pop();
            for (int i = 0; i < a.size(); i++) {
                hash = hash * power[a[i].second] + a[i].first;
                ll += a[i].second;
                ll %= 199193;
            }
            hash = hash * power[a.size()] + 7;
            a.clear();
            a.push_back(make_pair(hash, ll));
            int u = 0, v = 0;
            int wt = 0;
            while (u < a.size() || v < b.size()) {
                if (u == a.size()) {
                    qaq[++wt] = b[v];
                    v++;
                }
                else if (v == b.size()) {
                    qaq[++wt] = a[u];
                    u++;
                }
                else {
                    if (a[u] < b[v]) {
                        qaq[++wt] = a[u];
                        u++;
                    }
                    else if (a[u] > b[v]) {
                        qaq[++wt] = b[v];
                        v++;
                    }
                    else {
                        qaq[++wt] = a[u];
                        u++; v++;
                    }
                }
            }
            vector<ygorz> c;
            c.clear();
            c.push_back(qaq[1]);
            for (int i = 2; i <= wt; i++){
                c.push_back(qaq[i]);
            }
            st.push(c);
        }
        printf("%d\n", st.top().size());
    }
    return 0;
}

BZOJ1932——[Shoi2007]Setstack 集合堆栈机的更多相关文章

  1. BZOJ1932 [Shoi2007]Setstack 集合堆栈机

    妈呀...clj大爷太强啦! 原来还有set_union和set_intersection这种东西... 于是只要把栈顶的每个元素hash一下记录到一个vector里去就好了 /*********** ...

  2. 2018.08.28 集合堆栈机(模拟+STL)

    描述 中学数学里集合的元素往往是具体的数字,比如A = {1,2,3},B = {}(空集)等等.但是要特别注意,集合的元素也可以是另一个集合,比如说C = {{}},即说明C有且仅有一个元素--空集 ...

  3. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  4. [译]Python编写虚拟解释器

    使用Python编写虚拟机解释器 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou,密码shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux环 ...

  5. 零基础学Python--------第4章 序列的应用

    第4章 序列的应用 4.1序列 序列是一块用于存放多个值的连续内存空间,并且按上一定顺序排列,每一个值(称为元素)都分配一个数字,称为索引或位置.通过该索引可以取出相应的值.例如,我们可以把一家酒店看 ...

  6. 【转】CLR和JIT的理解、.NET反汇编学习

    CLR:通用语言运行时(Common Language Runtime)的简称,CLR是.NET框架的核心内容之一,可以把它看为一套标准资源,可以呗任何.NET程序使用.它包括:面向对象的编程模型.安 ...

  7. Atitit.虚拟机与指令系统的设计

    Atitit.虚拟机与指令系统的设计 1. 两种计算模型  ,堆栈机和状态机(基于寄存器的虚拟机1 1.1.1. 堆栈机1 1.1.2. 状态机2 2. 为什么状态机比堆栈机快呢?3 2.1. Sta ...

  8. (Python编程)Pickle对象

    Programming Python, 3rd Edition 翻译 最新版本见:http://wiki.woodpecker.org.cn/moin/PP3eD 19.4. Pickled Obje ...

  9. centos 7 搭建 LNMP ( Linux+Nginx+MySQL+PHP )

    操作系统 | CentOS Linux release 7.6.1810 (Core) [root@localhost ~# cat /etc/redhat-release CentOS Linux ...

随机推荐

  1. Visual Studio 当前上下文中不存在名称“ConfigurationManager”

    Visual Studio调试出现错误:当前上下文中不存在名称“ConfigurationManager” 解决方法: 1.System.Configuration引用这个dll参考:http://k ...

  2. ADS1.2安装教程

    工具/原料 ADS1.2 ADS1.2安装教程 1 在安装包内找到”Setup“,点击安装. 点击”Next“.然后进入License Agreement ,点击”Yes“. 点击了Yes之后,我们选 ...

  3. IDEA 搭建的SpringMVC Maven项目出现的问题

    1.添加jar包时,报添加某个jar包有问题,在pom.xml文件的project节点上有红波浪线 jar引用的maven地址没有问题,就是报错 解决办法:到本地仓库把相关jar包删掉重新下载 2.各 ...

  4. JavaScript学习笔记——BOM_window子对象_History、Location、Screnn对象

    javascript-History.Location.Screnn对象实例讲解 一.history对象 包含浏览器访问过的url 1.属性 length 返回浏览器历史记录的数量 alert(his ...

  5. [原创]用“人话”解释不精确线搜索中的Armijo-Goldstein准则及Wolfe-Powell准则

    [原创]用“人话”解释不精确线搜索中的Armijo-Goldstein准则及Wolfe-Powell准则 转载请注明出处:http://www.codelast.com/ line search(一维 ...

  6. jquermobile 安装

    代码 <script src="../Public/js/jquery-1.11.1.min.js"></script> <script src=&q ...

  7. SCP 命令(转)

    \ svn 删除所有的 .svn文件 find . -name .svn -type d -exec rm -fr {} \; linux之cp/scp命令+scp命令详解   名称:cp 使用权限: ...

  8. ehcache memcache redis 三大缓存男高音

    最近项目组有用到这三个缓存,去各自的官方看了下,觉得还真的各有千秋!今天特意归纳下各个缓存的优缺点,仅供参考!  Ehcache 在java项目广泛的使用.它是一个开源的.设计于提高在数据从RDBMS ...

  9. Swing杂记——Swing中引入Android的NinePatch技术,让Swing拥有Android的外观定制能力

    [摘要] 本文诣在展示如何在Swing中引入 NinePatch技术(早期有文章里中文译作九格图,暂且这么叫吧^_^,但此术非传统移动手机上的功能布局——九格图哦). [准备篇] Q:何为 NineP ...

  10. html页面 代码 编写的 一些 基本素养 约定 知识点

    hmtl代码书写也要养成一段一段的 区块代码, 每个区块代码 进行 html的 功能注释 自由文字的获得: (lorem ipsum: 乱数假文, 哑元文字) lorem ipsum: lipsum等 ...