2016弱校聯盟十一專場10.5---As Easy As Possible(倍增)

来源:http://www.cnblogs.com/chen9510/archive/2016/10/06/5934105.html
-Advertisement-
Play Games

題目鏈接 https://acm.bnu.edu.cn/v3/contest_show.php?cid=8506#problem/A problem description As we know, the NTU Final PK contest usually tends to be pretty ...


題目鏈接

https://acm.bnu.edu.cn/v3/contest_show.php?cid=8506#problem/A

 

problem description

As we know, the NTU Final PK contest usually tends to be pretty hard. Many teams got frustrated when participating NTU Final PK contest. So I decide to make the first problem as “easy” as possible. But how to know how easy is a problem? To make our life easier, we just consider how easy is a string. Here, we introduce a sane definition of “easiness”. The easiness of a string is the maximum times of “easy” as a subsequence of it. For example, the easiness of “eeaseyaesasyy” is 2. Since “easyeasy” is a subsequence of it, but “easyeasyeasy” is too easy. How to calculate easiness seems to be very easy. So here is a string s consists of only ‘e’, ‘a’, ‘s’, and ‘y’. Please answer m queries. The i-th query is a interval [li , ri ], and please calculate the easiness of s[li ..ri ].

Input

The first line contains a string s. The second line contains an integer m. Each of following m lines contains two integers li , ri . • 1 ≤ |s| ≤ 105 • 1 ≤ m ≤ 105 • 1 ≤ li ≤ ri ≤ |s| • s consists of only ‘e’, ‘a’, ‘s’, and ‘y’

Output

For each query, please output the easiness of that substring in one line.

Examples

standard input

easy

3

1 4

2 4

1 3

eeaseyaesasyy

4

1 13

2 12

2 10

3 11  

standard output

1

0

0

2

2

1

0

 

題意:給了一個只含有'e'  'a'  's'  'y'  的字元串然後m次詢問,每次詢問輸入l r 求這個區間含有多少個“easy”序列(每個“easy” 字元之間不需要連在一起);

思路:用倍增的思路來做,每個點只記錄最靠近它的在它左邊的那個字母的位置,比如'e'記錄前面的'y','a'記錄前面的'e','s'記錄前面的'a','y'記錄前面的's' 並註意記錄距離i最近(左邊的y)的y的位置(用p[i]存儲)  定義anc[i][j] 表示第i個字元前的第(1<<j)個字元的位置,這個可以用倍增做到 anc[i][j]=anc[anc[i][j-1]][j-1],  查詢時,先找到v=p[r] 然後找左邊有效字元個數,最後除以4 就是結果;

 

代碼如下:

#include <iostream>
#include <algorithm>
#include <stdio.h>
#include <cstring>
#include <queue>
using namespace std;
typedef long long LL;
char s[100005];
int a[100005],p[100005];
int anc[100005][21];
int mp[4];

int main()
{
    int m;
    while(scanf("%s",s+1)!=EOF)
    {
        int len=strlen(s+1);
        for(int i=1;i<=len;i++)
        {
            if(s[i]=='e') a[i]=0;
            else if(s[i]=='a') a[i]=1;
            else if(s[i]=='s') a[i]=2;
            else a[i]=3;
        }
        memset(mp,0,sizeof(mp));
        for(int i=1;i<=len;i++)
        {
            int pre=(a[i]-1+4)%4;
            anc[i][0]=mp[pre];
            mp[a[i]]=i;
            p[i]=mp[3];
        }
        for(int i=1;i<=20;i++)
        {
            for(int j=1;j<=len;j++)
            {
                anc[j][i]=anc[anc[j][i-1]][i-1];
            }
        }
        scanf("%d",&m);
        while(m--)
        {
            int l,r;
            int sum=1;
            scanf("%d%d",&l,&r);
            int v=p[r];
            for(int i=20;i>=0;i--)
            {
                if(anc[v][i]>=l){
                    sum+=(1<<i);
                    v=anc[v][i];
                }
            }
            printf("%d\n",sum/4);
        }
    }
    return 0;
}

 


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

-Advertisement-
Play Games
更多相關文章
  • Netbeans 8.2在這個國慶期間終於發佈了,其與PHP相關的新特性主要有: 支持PHP 7 詳見前面翻譯的一篇文章: "Netbeans 8.2將支持PHP 7" 編輯器功能增強 文檔好像沒有明確說明,我也還沒有發現。 PHP項目支持自定義註解 操作如下圖: 然後,當你在編寫代碼註解時,就可以 ...
  • C++類中的虛表結構是C++對象模型中一個重要的知識點,這裡咱們就來深入分析下虛表的在記憶體中的結構。 C++一個類中有虛函數的話就會有一個虛表指針,其指向對應的虛表,一般一個類只會有一個虛表,每個虛表有多個”插槽”,每個插槽存放一個虛函數的地址。插槽中的內容可以被覆蓋,子類如果重寫了父類中的虛函數, ...
  • 代碼如下: import java.util.Enumeration; import java.util.Iterator; import java.util.Map; import java.util.Map.Entry; import java.util.Properties; import j... ...
  • For collecting and analyzing data. 【啟示】本處所分享的內容均是筆者從一些專業書籍中學習所得,也許會有一些自己使用過程中的技巧、心得、小經驗一類的,但遠比不上書中所講述的精彩翔實。只因自己在學習過程中深感在R爬蟲應用中互聯網可搜索的公開資源並不如其它知識豐富,特此稍 ...
  • 博主python菜鳥,本想在win7下安裝一個pyquery玩玩爬蟲,折騰了好幾天終於搞好了,發現python這坑不是一般的深啊。 有一部分沒有截圖,請諒解 python版本3.4 1.下載easy_install和pip,這步跳過,python 3.X預設自帶 2.嘗試用pip pyquery i ...
  • 說明:在我們調試C語言的過程中,經常會遇到duplicate symbol錯誤(在Mac平臺下利用Xcode集成開發環境)。如下圖: 一.簡單分析一下C語言程式的開發步驟。 由上圖我們可以看出C語言由編寫源程式->編譯->鏈接->運行幾個步驟進行。 編寫源程式: C語言的源文件的擴展名為.c,源文件 ...
  • 批處理是一次性向資料庫發出多條查詢指令,一起執行Statement 介面定義的方法:|—增加批處理語句: |—執行批處理: PreparedStatement介面定義的方法:增加批處理:public void addBatche()throws SQLexceeption public class ...
  • 下麵是我今天下午用PHP寫的一個生成圖片驗證碼demo,僅供參考。這個demo總共分為4個文件,具體代碼如下: ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...