1507: [NOI2003]Editor(塊狀鏈表)

来源:http://www.cnblogs.com/mjtcn/archive/2017/12/24/8097313.html
-Advertisement-
Play Games

1507: [NOI2003]Editor Description Input 輸入文件editor.in的第一行是指令條數t,以下是需要執行的t個操作。其中: 為了使輸入文件便於閱讀,Insert操作的字元串中可能會插入一些回車符,請忽略掉它們(如果難以理解這句話,可以參考樣例)。 除了回車符之外 ...


1507: [NOI2003]Editor

Time Limit: 5 Sec  Memory Limit: 162 MB
Submit: 4157  Solved: 1677
[Submit][Status][Discuss]

Description

Input

輸入文件editor.in的第一行是指令條數t,以下是需要執行的t個操作。其中: 為了使輸入文件便於閱讀,Insert操作的字元串中可能會插入一些回車符,請忽略掉它們(如果難以理解這句話,可以參考樣例)。 除了回車符之外,輸入文件的所有字元的ASCII碼都在閉區間[32, 126]內。且行尾沒有空格。 這裡我們有如下假定:  MOVE操作不超過50000個,INSERT和DELETE操作的總個數不超過4000,PREV和NEXT操作的總個數不超過200000。  所有INSERT插入的字元數之和不超過2M(1M=1024*1024),正確的輸出文件長度不超過3M位元組。  DELETE操作和GET操作執行時游標後必然有足夠的字元。MOVE、PREV、NEXT操作必然不會試圖把游標移動到非法位置。  輸入文件沒有錯誤。 對C++選手的提示:經測試,最大的測試數據使用fstream進行輸入有可能會比使用stdio慢約1秒。

Output

輸出文件editor.out的每行依次對應輸入文件中每條GET指令的輸出。

Sample Input

15
Insert 26
abcdefghijklmnop
qrstuv wxy
Move 15
Delete 11
Move 5
Insert 1
^
Next
Insert 1
_
Next
Next
Insert 4
.\/.
Get 4
Prev
Insert 1
^
Move 0
Get 22

Sample Output

.\/.
abcde^_^f.\/.ghijklmno

 

 

code

  1 #include<cstdio>
  2 #include<cstring>
  3 
  4 const int MAXL = 2100000; 
  5 const int Block_size = 5010; 
  6 const int Block_num = 600; 
  7 int Number[Block_num],Tot;
  8 int nxt[Block_num],siz[Block_num]; 
  9 char data[Block_num][Block_size]; 
 10 char str[MAXL],s[20];
 11 
 12 void Init() {
 13     for (int i=1; i<Block_num; ++i) 
 14         Number[i] = i;
 15     Tot = 1;
 16     nxt[0] = -1;siz[0] = 0; 
 17 }
 18 int Getnum() {
 19     return Number[Tot++];
 20 } 
 21 void Delnum(int x) {
 22     Number[--Tot] = x;
 23 }
 24 int find(int &pos) {
 25     int k = 0;
 26     while (k != -1 && pos > siz[k]) {
 27         pos -= siz[k];
 28         k = nxt[k];
 29     }
 30     return k;
 31 }
 32 void Madenews(int cur,int news,int num,char str[]) {
 33     if (news!=-1) {
 34         nxt[news] = nxt[cur];
 35         siz[news] = num;
 36         memcpy(data[news],str,num);
 37     }
 38     nxt[cur] = news;
 39 } 
 40 void split(int cur,int pos) {
 41     if (cur==-1 || pos==siz[cur]) return ;
 42     int news = Getnum();
 43     Madenews(cur,news,siz[cur]-pos,data[cur]+pos);
 44     siz[cur] = pos;
 45 } 
 46 void Merge(int x,int y) {
 47     memcpy(data[x]+siz[x],data[y],siz[y]);
 48     siz[x] += siz[y];
 49     nxt[x] = nxt[y];
 50     Delnum(y);
 51 } 
 52 void Maintain() {
 53     int cur = 0; 
 54     while (cur != -1) { 
 55         int p = nxt[cur];
 56         while (p != -1 && siz[cur] + siz[p] <= Block_size) {
 57             Merge(cur,p);
 58             p = nxt[cur];
 59         }
 60         cur = nxt[cur];
 61     }
 62 }
 63 void Insert(int pos,int num,char str[]) {
 64     int cur = find(pos);
 65     split(cur,pos);
 66     int cnt = 0;
 67     while (cnt + Block_size <= num) {
 68         int news = Getnum();
 69         Madenews(cur,news,Block_size,str+cnt);
 70         cur = news;
 71         cnt += Block_size;
 72     }
 73     if (num - cnt) {
 74         int news = Getnum();
 75         Madenews(cur,news,num-cnt,str+cnt);
 76     } 
 77     Maintain();
 78 }
 79 void Erase(int pos,int num) {
 80     int cur = find(pos);
 81     split(cur,pos);
 82     int p = nxt[cur]; 
 83     while (p != -1 && num > siz[p]) {
 84         num -= siz[p];
 85         p = nxt[p];
 86     }
 87     split(p,num);
 88     p = nxt[p];
 89     for (int i=nxt[cur]; i!=p; i=nxt[cur]) {
 90         nxt[cur] = nxt[i];
 91         Delnum(i);
 92     }
 93     Maintain();
 94 } 
 95 void Getdata(int pos,int num,char str[]) {
 96     int cur = find(pos);
 97     int cnt = siz[cur] - pos;
 98     if (num < cnt) cnt = num;
 99     memcpy(str,data[cur]+pos,cnt);
100     int tmp = nxt[cur];
101     while (tmp!=-1 && cnt+siz[tmp] <= num) {
102         memcpy(str+cnt,data[tmp],siz[tmp]);
103         cnt += siz[tmp];
104         tmp = nxt[tmp];
105     }
106     if (num - cnt && tmp != -1) 
107         memcpy(str+cnt,data[tmp],num-cnt);
108     str[num] = '\0';
109 } 
110 int main() {
111     Init();
112     int Nowpos = 0,opt,num;
113     scanf("%d",&opt);
114     while (opt) {
115         opt--;
116         scanf("%s",s);
117         if (s[0]=='M') scanf("%d",&Nowpos);
118         else if (s[0]=='I')    {
119             scanf("%d",&num);
120             for (int i=0; i<num; ++i) {
121                 scanf("%c",&str[i]);
122                 if (str[i]<32 || str[i]>126) --i;
123             }
124             Insert(Nowpos,num,str);    
125         }
126         else if (s[0]=='D') {
127             scanf("%d",&num);
128             Erase(Nowpos,num);
129         }
130         else if (s[0]=='G') {
131             scanf("%d",&num);
132             Getdata(Nowpos,num,str);
133             printf("%s\n",str);        
134         }
135         else if (s[0]=='P') --Nowpos;
136         else ++Nowpos;
137     }
138     return 0;
139 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 章節目錄 "【quickhybrid】如何實現一個跨平臺Hybrid框架" "【quick hybrid】架構一個Hybrid框架" "【quick hybrid】H5和Native交互原理" "【quick hybrid】JSBridge的實現" "【quick hybrid】H5和原生的職責劃分 ...
  • 白駒過隙,時光荏苒 大概去年這個時候寫了angular 結合webpack的一套前端方案,今年此時祭出vue2結合webpack2的一套前端方案。 明年的這個時候我又是在做什麼... 讀在最前面: 1、本文講述Vue,Webpack 模塊化、SEO優化、全瀏覽器相容(ie8以上)、圖片輪播等案例方案 ...
  • 8月初離職,來到現在的新東家負責一個新的項目。而我最近開發的兩個webapp一直都是以Vue為主,這也是這篇文章的由來。 正文前的胡侃&一點點吐槽 在經歷了兩個公司不同的項目後,發現都存在一個很致命卻又如此相似的問題。就是領導層的決策,導致項目的開發後期加班嚴重。領導們普遍都是先DIY,然後等到項目 ...
  • 整體思路 代碼部分 2.對左屏(相機偏移的場景)重新進行渲染(暫時解決方案,對相機外的場景同樣進行渲染,存在的問題:效率太低) 有待解決的問題 相機偏移後(左屏),應當對場景(左屏)重新進行渲染。具體指 ...
  • for(var i=0;i<as.length;i++){ as[i].onmouseover=function(){this.style.backgroundColor='grey';} as[i].onmouseout=function(){this.style.backgroundColor= ...
  • <script>window.onload = function(){ var u = navigator.userAgent; var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); if(isiOS){ if(location.search ...
  • spring mvc簡介與運行原理 Spring的模型-視圖-控制器(MVC)框架是圍繞一個DispatcherServlet來設計的,這個Servlet會把請求分發給各個處理器,並支持可配置的處理器映射、視圖渲染、本地化、時區與主題渲染等,甚至還能支持文件上傳。 原理.png (1) Http請求 ...
  • 題目描述 如題,給定一棵有根多叉樹,請求出指定兩個點直接最近的公共祖先。 輸入輸出格式 輸入格式: 第一行包含三個正整數N、M、S,分別表示樹的結點個數、詢問的個數和樹根結點的序號。 接下來N-1行每行包含兩個正整數x、y,表示x結點和y結點之間有一條直接連接的邊(數據保證可以構成樹)。 接下來M行 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...