集合棧電腦(The SetStack Computer, ACM/ICPC NWERC 2006,Uva12096)

来源:https://www.cnblogs.com/MarkKobs-blog/archive/2019/03/01/10459077.html
-Advertisement-
Play Games

集合棧電腦(The SetStack Computer, ACM/ICPC NWERC 2006,Uva12096) 題目描述 有一個專門為了集合運算而設計的“集合棧”電腦。該機器有一個初始為空的棧,並且支持以下操作: PUSH:空集“{}”入棧 DUP:把當前棧頂元素複製一份後再入棧 UNIO ...


集合棧電腦(The SetStack Computer, ACM/ICPC NWERC 2006,Uva12096)

題目描述

有一個專門為了集合運算而設計的“集合棧”電腦。該機器有一個初始為空的棧,並且支持以下操作:
PUSH:空集“{}”入棧
DUP:把當前棧頂元素複製一份後再入棧
UNION:出棧兩個集合,然後把兩者的並集入棧
INTERSECT:出棧兩個集合,然後把二者的交集入棧
ADD:出棧兩個集合,然後把先出棧的集合加入到後出棧的集合中,把結果入棧
       每次操作後,輸出棧頂集合的大小(即元素個數)。例如棧頂元素是A={ {}, {{}} }, 下一個元素是B={ {}, {{{}}} },則:
UNION操作將得到{ {}, {{}}, {{{}}} },輸出3.
INTERSECT操作將得到{ {} },輸出1
ADD操作將得到{ {}, {{{}}}, { {}, {{}} } },輸出3.
樣例輸入

6
PUSH
PUSH
UNION
PUSH
PUSH
ADD

樣例輸出

0
0
0
0
0
1

代碼實現

#define LOCAL
#include<set>
#include<stack>
#include<iostream>
#include<map>
#include<vector>
#include<algorithm> // for set_union set_intersection
using namespace std;

/*
push:空集{}入棧
union:出棧兩個集合,然後把兩者的並集入棧
intersect:出棧兩個集合,然後把二者的交集入棧
add:出棧兩個集合,然後把先出棧的集合加入到後出棧的集合中,把結果入棧。
*/
typedef set<int> Set;
map<Set,int> IDcache; //set - id  such as:IDcache[set]
vector<Set> SetCache; //id - cache such as:SetCache[id]
stack<int> s;
int ID(Set x){ //光一個map數據結構還不夠,這是因為有可能一個Set還沒有對應的id,所以這個函數應該包括的功能有:1.創建id(如果沒有) 2.返回id
    if(!IDcache.count(x)){
        SetCache.push_back(x);
        IDcache[x]=SetCache.size()-1;//!!!騷操作
    }
    return IDcache[x];
}
int n;
int main(){
    #ifdef LOCAL
    freopen("data.in","r",stdin);
    freopen("data.out","w",stdout);
    #endif

    cin>>n;
    while(n--){
        string exec;
        cin>>exec;
        if(exec[0] == 'P') s.push(ID(Set()));
        else if(exec[0] == 'D') s.push(s.top());
        else{
            Set x1 = SetCache[s.top()];
            s.pop();
            Set x2 = SetCache[s.top()];
            s.pop();
            Set x;
            if(exec[0] == 'U') set_union(x1.begin(),x1.end(),x2.begin(),x2.end(),inserter(x,x.begin()));//!!!inserter
            if(exec[0] == 'I') set_intersection(x1.begin(),x1.end(),x2.begin(),x2.end(),inserter(x,x.begin()));//!!!inserter
            if(exec[0] == 'A'){
                x=x2;
                x.insert(ID(x1));
            }
            s.push(ID(x));
        }
        cout<<SetCache[s.top()].size()<<endl;
    }
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 題意 "題目鏈接" 可持久化01Trie板子題 對於兩個操作分別開就行了 cpp include using namespace std; const int MAXN = 4e5 + 10, SS = MAXN 42 + 10; const int B = 31; inline int read( ...
  • Node.js 是一個基於 Chrome V8 引擎的 JavaScript 運行環境,用來方便地搭建快速的易於擴展的網路應用。Node.js 使用了一個事件驅動、非阻塞式 I/O 的模型,使其輕量又高效,非常適合運行在分散式設備的數據密集型的實時應用。在阿裡雲的Centos系統上,可以採用NVM安 ...
  • 早些年做CRM用到的一個金額轉換函數,今天從舊項目中拿出來記錄一下。金額轉換的函數方法有很多,都很不錯。不過這個是小崔剛工作的時候寫的一個轉換函數,多少還是有點紀念意義。如有問題請朋友們指出,小崔及時修正。謝謝啦! 廢話不多說直接上代碼: 以上是基礎轉換代碼,在這個基礎上進行二次改造: 運行結果: ...
  • 登錄驗證碼 Servlet / 從請求中獲取數據,獲取驗證碼的session的值轉為String類型, 銷毀,防止返回後驗證碼不刷新,重新驗證成功 判斷驗證碼是否相同(忽略大小寫) 相同:創建user對象調用service層的方法驗證返回結果是否為空 為空:創建session:儲存錯誤信息,轉發,登 ...
  • 本文是接著上篇博客寫的:Spring boot 入門(三):SpringBoot 集成結合 AdminLTE(Freemarker),利用 generate 自動生成代碼,利用 DataTable 和 PageHelper 進行分頁顯示。按照前面的博客,已經可以搭建一個簡單的 Spring Boot ...
  • 小談: 帖主妥妥的一名"中"白了哈哈哈。軟工的大三狗了,也即將找工作,懷著絲絲忐忑接受社會的安排。這是第一次寫博客(/汗顏),其實之前在學習探索過程中,走了不少彎路,爬過不少坑。真的挺感謝一路上的前輩們的博客也好,隨筆也好,哪怕是評論,或多或少解決了一些問題。我感覺學技術的過程中,記錄下自己解決問題 ...
  • 長期以來都想用python對Excel進行一些列的操作,但由於某種神秘的力量控制著我,一直未果,今天有幸用requests模塊和BeautifulSoup模塊進行爬蟲練習,拿到了一大批數據,照我以前,都只是用字典啊、列表啊,或者文本文件存放,之前沒覺得哪裡不好,但今天的我很奇怪,怎麼看怎麼不爽,而且 ...
  • 嘔,大一下學期的第一周結束啦,一周過的挺快也挺多出乎意料的事情的~ 隨之而來各種各樣的任務也來了,嘛畢竟是大學嘛,有點上進心的人多多少少都會接到不少任務的,忙也正常啦~端正心態 開心面對就好啦~ 今天突然回顧了一下《從你的全世界路過》這本書和電影,莫名的感悟涌上心頭,收集到了一些走入人心的一些語句: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...