P2776 [SDOI2007]小組隊列

来源:http://www.cnblogs.com/zwfymqz/archive/2017/06/17/7041370.html
-Advertisement-
Play Games

題目背景 嘛,這道非常簡單的給大家提供信心的省選題洛谷居然沒有! 這麼簡單的題怎麼可以沒有! 給大家提升士氣是義不容辭的責任! 所以我就來補一下啦.. 值得一提的是,標程是我自己做的.. 很渣,因為數據很水所以能AC.. 大神勿噴.. 題目描述 有 m 個小組, n 個元素,每個元素屬於且僅屬於一個 ...


題目背景

嘛,這道非常簡單的給大家提供信心的省選題洛谷居然沒有!

這麼簡單的題怎麼可以沒有!

給大家提升士氣是義不容辭的責任!

所以我就來補一下啦..

值得一提的是,標程是我自己做的..

很渣,因為數據很水所以能AC..

大神勿噴..

題目描述

有 m 個小組, n 個元素,每個元素屬於且僅屬於一個小組。

支持以下操作:

push x:使元素 x 進隊,如果前邊有 x 所屬小組的元素,x 會排到自己小組最後一個元素的下一個位置,否則 x 排到整個隊列最後的位置。

pop:出隊,彈出隊頭並輸出出隊元素,出隊的方式和普通隊列相同,即排在前邊的元素先出隊。

輸入輸出格式

輸入格式:

第一行有兩個正整數 n, m,分別表示元素個數和小組個數,元素和小組均從 0 開始編號。

接下來一行 n 個非負整數 Ai,表示元素 i 所在的小組。

接下來一行一個正整數 T ,表示操作數。

接下來 T 行,每行為一個操作。

輸出格式:

對於每個出隊操作輸出一行,為出隊的元素。

輸入輸出樣例

輸入樣例#1:
4 2
0 0 1 1
6
push 2
push 0
push 3
pop
pop
pop
輸出樣例#1:
2
3
0

說明

對於30%的數據,1≤n≤100,1≤m≤10,T≤50。

對於100%的數據,1≤n≤100000,1≤m≤300,T≤100000,輸入保證操作合法。

第一次用到二維隊列

用last來表示每一個小組內元素出現的順序

q隊列表示每一個小組出現的順序

我們想一下,如果一個元素所屬的小組在之前出現過

那麼我們直接加到last隊列里就好

這樣可以保證按照小組的順序輸出

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<queue>
 6 using namespace std;
 7 int read(int & n)
 8 {
 9     char c='.';int x=0,flag=0;
10     while(c<'0'||c>'9')
11     {
12         c=getchar();
13         if(c=='-')flag=1;
14     }
15     while(c>='0'&&c<='9')
16     {
17         x=x*10+(c-48);
18         c=getchar();
19     }
20     if(flag==1)n=-x;
21     else n=x;
22 }
23 const int MAXN=10000001;
24 queue<int>q,last[301];
25 int group[MAXN];
26 int main()
27 {
28     int n,m,p,meiyong;
29     read(n);read(meiyong);
30     for(int i=0;i<n;i++)
31         read(group[i]);
32     read(m);
33     for(int i=1;i<=m;i++)
34     {
35         string s;
36         cin>>s;
37         if(s=="push")
38         {
39             read(p);
40             if(last[group[p]].empty())
41             q.push(group[p]);
42                 last[group[p]].push(p);
43         }
44         else
45         {
46             printf("%d\n",last[q.front()].front());
47             last[q.front()].pop();
48             if(last[q.front()].empty())
49             q.pop();
50             
51         }
52     }
53     return 0;
54 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、預設裝配方式 代碼通過getBean();方式從容器中獲取指定的Bean實例,容器首先會調用Bean類的無參構造器,創建空值的實例對象。 舉例: 首先我在applicationContext.xml配置文件中配置了一個bean: 創建SomeServiceImpl對象,但需要註意的是該類的只具有 ...
  • 前 言 PHP 學習了好久的PHP,今天做一個可以後臺交互的登錄頁和註冊頁,沒做什麼判斷,簡單的瞭解一下。 具體的內容分析如下: ① PHP中的數據傳輸-->>由註冊頁傳輸給註冊頁後臺-->>註冊頁後臺經過轉碼保存實例化的文件 ② 在登錄頁輸入賬戶密碼,點擊登錄時,獲得觸發函數:獲得由後臺傳輸過來的 ...
  • 1.==,is的使用 總結 ·is是比較兩個引用是否指向了同一個對象(引用比較)。 ·==是比較兩個對象是否相等。 2.深拷貝、淺拷貝 1.淺拷貝 淺拷貝是對於一個對象的頂層拷貝 通俗的理解是:拷貝了引用,並沒有拷貝內容 2.深拷貝 深拷貝是對於一個對象所有層次的拷貝(遞歸) 進一步理解拷貝 進一步 ...
  • 題目背景 蕾米莉亞的紅霧異變失敗後,很不甘心。 題目描述 經過上次失敗後,蕾米莉亞決定再次發動紅霧異變,但為了防止被靈夢退治,她決定將紅霧以奇怪的陣勢釋放。 我們將幻想鄉看做是一個n*m的方格地區,一開始沒有任何一個地區被紅霧遮蓋。蕾米莉亞每次站在某一個地區上,向東南西北四個方向各發出一條無限長的紅 ...
  • 一、線性表 原理:零個或多個同類數據元素的有限序列 原理圖: 特點 : 1、有序性 2、有限性 3、同類型元素 4、第一個元素無前驅,最後一個元素無後繼,中間的元素有一個前驅並且有一個後繼 線性表是一種邏輯上的數據結構,在物理上一般有兩種實現 順序實現和鏈表實現 二、基於數組的 線性表順序實現 原理 ...
  • 文件上傳 配置伺服器虛擬地址: 文件獲取與存儲 獲取伺服器虛擬目錄上的文件 文件獲取與存儲 獲取伺服器虛擬目錄上的文件 獲取伺服器虛擬目錄上的文件 ...
  • 文件編碼: ①gbk編碼:中文占用2個位元組,英文占用1個位元組 File類常用API的使用: file類的遍歷目錄 RomdonAccessFile基本操作 五、位元組流 ...
  • 裝飾器 裝飾器本質上是一個Python函數,它可以讓其他函數在不需要做任何代碼變動的前提下增加額外功能,裝飾器的返回值也是一個函數對象。 先看簡單例子: 現有一個新的需求,希望可以記錄下函數的運行時間,需要在代碼中計算時間的代碼: login()等多個函數也有類型的需求,怎麼做?若在每個函數內都寫一 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...