洛谷 P1136 迎接儀式 解題報告

P1136 迎接儀式

題目描述

LHX教主要來X市指導OI學習工作了。為了迎接教主,在一條道路旁,一群Orz教主er穿著文化衫站在道路兩旁迎接教主,每件文化衫上都印著大字。一旁的Orzer依次擺出“歡迎歡迎歡迎歡迎……”的大字,但是領隊突然發現,另一旁穿著“教”和“主”字文化衫的Orzer卻不太和諧。

為了簡單描述這個不和諧的隊列,我們用“\(j\)”替代“教”,“\(z\)”替代“主”。而一個“\(j\)”與“\(z\)”組成的序列則可以描述當前的隊列。為了讓教主看得盡量舒服,你必須調整隊列,使得“\(jz\)”子串盡量多。每次調整你可以交換任意位置上的兩個人,也就是序列中任意位置上的兩個字母。而因為教主馬上就來了,時間僅夠最多作\(K\)次調整(當然可以調整不滿\(K\)次),所以這個問題交給了你。

輸入輸出格式

輸入格式:

第一行包含\(2\)個正整數\(N\)\(K\),表示了序列長度與最多交換次數。

第二行包含了一個長度為\(N\)的字符串,字符串僅由字母“\(j\)”與字母“\(z\)”組成,描述了這個序列。

輸出格式:

一個非負整數,為調整最多\(K\)次后最后最多能出現多少個“\(jz\)”子串。

數據規模與約定

對于\(10\%\)的數據,有\(N≤10\)

對于\(30\%\)的數據,有\(K≤10\)

對于\(40\%\)的數據,有\(N≤50\)

對于\(100\%\)的數據,有\(N≤500,K≤100\)


神題啊,膜拜膜拜~~

看起來就是地痞,考慮一下如何把狀態都給丟進去

因為一次涉及兩個地方的位置,所以我們很難把這樣的狀態準確表示。

我們可以考慮先找一些特殊的突破點或者顯然成立的貪心性質

說到特殊,這個序列的字符集只有\(2\)

說道性質,很顯然,一個位置不會被改兩次,兩個一樣字符的不會被改。

以上是我開了上帝視角得出的,事實上,我們可能可以想到它們,但是它們不一定會真正啟發到我們

還是要看做題積累的經驗

下面上正解:

\(dp_{i,j,k}\)代表在位置\(i\),\('j'\)這個字符被交換過\(j\)次,\('z'\)這個字符被交換過\(k\)

請注意,這個交換是存在匹配的,但我們只管匹配,并不在乎具體誰和誰交換過

如果你沒能理解上面這句話,請看看狀態轉移方程

因為一個匹配需要兩個字符,所以我們從\(當前位置-2\)的地方之前進行更新

dp[i][j][k]=dp[i-1][j][k];
if(s[i]=='j'&&s[i-1]=='z'&&j&&k)dp[i][j][k]=max(dp[i][j][k],dp[i-2][j-1][k-1]+1);
if(s[i]=='z'&&s[i-1]=='j')dp[i][j][k]=max(dp[i][j][k],dp[i-2][j][k]+1);
if(s[i]=='j'&&s[i-1]=='j'&&j)dp[i][j][k]=max(dp[i][j][k],dp[i-2][j-1][k]+1);
if(s[i]=='z'&&s[i-1]=='z'&&k)dp[i][j][k]=max(dp[i][j][k],dp[i-2][j][k-1]+1);
if(j==k) ans=max(ans,dp[i][j][k]);

格外注意一下答案更新的地方,相等時更新代表什么,其實就是代表匹配上去了,這些東西都在互有交換,但現在交換次數一樣了,所以我們可以更新答案

值得一提的是,我們其實并沒有單以位置劃分狀態,可以注意到,匹配的位置是前后都有的,我們是把位置和交換的狀態放在一起,才做到了無后效性

個人拙見,如有錯誤,煩請提出


Code:

#include <cstdio>
#include <cstring>
int max(int x,int y){return x>y?x:y;}
const int N=502;
int dp[N][103][103],n,m,ans;
char s[N];
int main()
{scanf("%d%d%s",&n,&m,s+1);memset(dp,-0x3f,sizeof(dp));dp[0][0][0]=dp[1][0][0]=dp[1][s[1]=='j'][s[1]=='z']=0;for(int i=2;i<=n;i++)for(int j=0;j<=m;j++)for(int k=0;k<=m;k++){dp[i][j][k]=dp[i-1][j][k];if(s[i]=='j'&&s[i-1]=='z'&&j&&k)dp[i][j][k]=max(dp[i][j][k],dp[i-2][j-1][k-1]+1);else if(s[i]=='z'&&s[i-1]=='j')dp[i][j][k]=max(dp[i][j][k],dp[i-2][j][k]+1);else if(s[i]=='j'&&s[i-1]=='j'&&j)dp[i][j][k]=max(dp[i][j][k],dp[i-2][j-1][k]+1);else if(s[i]=='z'&&s[i-1]=='z'&&k)dp[i][j][k]=max(dp[i][j][k],dp[i-2][j][k-1]+1);if(j==k) ans=max(ans,dp[i][j][k]);}printf("%d\n",ans);return 0;
}

2018.9.5

轉載于:https://www.cnblogs.com/butterflydew/p/9594426.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/249569.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/249569.shtml
英文地址,請注明出處:http://en.pswp.cn/news/249569.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

spring源碼分析-core.io包里面的類

前些日子看《深入理解javaweb開發》時&#xff0c;看到第一章java的io流&#xff0c;發覺自己對io流真的不是很熟悉。然后看了下JDK1.7中io包的一點點代碼&#xff0c;又看了org.springframework.core.io包的一些類和組織方式&#xff0c;當作是學習吧。總結一下。 先掛下spri…

對類Vue的MVVM前端庫的實現

關于實現MVVM&#xff0c;網上實在是太多了&#xff0c;本文為個人總結&#xff0c;結合源碼以及一些別人的實現 關于雙向綁定 vue 數據劫持 訂閱 - 發布ng 臟值檢查backbone.js 訂閱-發布(這個沒有使用過&#xff0c;并不是主流的用法)雙向綁定&#xff0c;從最基本的實現來說…

java.util.prefs.Preferences

我們經常需要將我們的程序中的設定&#xff0c;如窗口位置&#xff0c;開啟過的文件&#xff0c;用戶的選項設定等數據記錄下來&#xff0c;以做便用戶下一次開啟程序能繼續使用這些數據。 以前我們通常的做法是使用Properties類&#xff0c;它提供以下方法: void load(InputS…

django的母板系統

一.母板渲染語法 1.變量 {{ 變量 }} 2.邏輯 {% 邏輯語 %} 二.變量 在母板中有變量時,母板引擎會去反向解析找到這個傳來的變量,然后替換掉. .(點),在母板中是深度查詢據點符,它的查詢順序: 字典 > 屬性或方法 > 數字索引 三.過濾器 1.語法 {{ value|filter_name:參數}} 2…

python學習總結----時間模塊 and 虛擬環境(了解)

python學習總結----時間模塊 and 虛擬環境&#xff08;了解&#xff09; time- sleep&#xff1a;休眠指定的秒數(可以是小數) - time&#xff1a;獲取時間戳# 獲取時間戳(從1970-01-01 00:00:00到此刻的秒數)t time.time()print(t) - localtime&#xff1a;將時間戳轉換為對象…

【CSS】flex的常用布局

1、垂直居中&#xff0c;寫在父級上div{display: flex;justify-content: center;align-items: center; } 2、flex-左右兩端&#xff0c;垂直居中該布局在移動端較為常見<style> .wrap{display: flex;justify-content: space-between;align-items: center;width: 200px;he…

java.util.Properties

ava.util.Properties是對properties這類配置文件的映射。支持key-value類型和xml類型兩種 首先&#xff0c;新建一個文件&#xff0c;如圖&#xff1a; 然后再Java代碼段輸入如下代碼&#xff1a; import java.io.FileInputStream; import java.io.InputStream; import java…

Xpath使用方法

Xpath使用方法 注&#xff1a;默認死格式 先寫 //* 代表定位頁面下所有元素 1、Xpath支持ID、Class、Name定位功能 通過ID定位 //*[idkw]通過Class定位//*[classclass_name]通過Name定位//*[namename]-----------------------------------------------------------------------…

為什么這么多爛代碼?

在國內&#xff0c;有經驗的程序員都當領導了&#xff0c;領導又不寫代碼&#xff0c;那代碼只能讓剛入行的新手寫了&#xff0c;然后就是隨意堆砌&#xff0c;完成功能就行&#xff0c;所以目前我盡量不寫爛代碼&#xff0c;并盡量堅持改造已有的爛代碼&#xff0c;在我眼中&a…

Spring-boot 打成jar包后使用外部配置文件

官網說明 第一種是在jar包的同一目錄下建一個config文件夾&#xff0c;然后把配置文件放到這個文件夾下&#xff1b; 第二種是直接把配置文件放到jar包的同級目錄&#xff1b; 第三種在classpath下建一個config文件夾&#xff0c;然后把配置文件放進去&#xff1b; 第四種是在c…

acm模板生成

為迎接&#xff0c;接下來的區域賽&#xff0c;要做好準備(雖然不是特別有信心&#xff0c;但是還是要鼓勵自己&#xff0c;可以取得收獲的&#xff0c;加油) acm_latex模板&#xff1a; https://www.cnblogs.com/palayutm/p/6444833.html#e69bb4e696b0_1 windows下安裝texlive…

UI自動化之元素定位(xpath、css)

很早之前就已經寫過自動化了&#xff0c;不過點著功能久了就會容易忘記元素定位&#xff0c;尤其是xpath和css定位&#xff0c;所以就花點時間做下總結收集。 xpath有兩種定位&#xff1a; 一.絕對路徑&#xff08;不推薦使用&#xff0c;除非已經使用了所有方式仍然無法定位&a…

屬性編輯器PropertyEditor

在Spring配置文件里&#xff0c;我們往往通過字面值為Bean各種類型的屬性提供設置值&#xff1a;不管是double類型還是int類型&#xff0c;在配置文件中都對應字符串類型的字面值。BeanWrapper填充Bean屬性時如何將這個字面值轉換為對應的double或int等內部類型呢&#xff1f;我…

郵箱驗證

public class Emailstandard { /* * 以數字或字母開頭 * 之前可以含有數字,字母,下劃線,點 * 有且只有一個 * 之后只能含有數字,字母 * 必須以.com或者.cn結尾 * */ public static void main(String[] args) { Scanner sca new Scanner(…

python第二十八課——編碼小常識

2.內存和硬盤&#xff1a;內存&#xff1a;計算機硬件組成部分之一&#xff0c;它是一個容器&#xff0c;用來存儲數據&#xff1b;處理數據速度快&#xff0c;存儲數據量小&#xff1b;斷電死機數據會丟失&#xff0c;短暫性存儲數據硬盤&#xff1a;計算機硬件組成部分之一&a…

Javadoc 使用詳解

很多程序對Javadoc都不重視&#xff0c;認識不到Javadoc的作用&#xff0c;很多人都是這樣認為的&#xff1a;“我只要寫好功能就夠了&#xff0c;寫Javadoc太浪費時間&#xff0c;也沒啥作用&#xff0c;還不如用寫Javadoc的時間再多些個功能呢&#xff01;”&#xff0c;我們…

Linux下查看當前文件大小的命令

1、ls -lht 列出每個文件的大小和當前目錄所有文件大小總和 2、du -sh * 列出當前文件夾下的所有子文件的大小 看你需要啥樣的&#xff0c;自己來吧 轉載于:https://www.cnblogs.com/xbxxf/p/9619818.html

(13)UniquePathIII

一、問題描述 給定一個二維數組。 數組只有一個元素是1&#xff0c;是起點數組只有一個元素是2&#xff0c;是終點數組中的0是必須經過的地方數組中的-1是障礙不可通過從起始點到終點一共有多少路徑&#xff1f; 二、思路 DFS 三、Code 1 package algorithm;2 3 /**4 * Create…

Spring IOC-BeanFactory的繼承體系結構

本文主要介紹BeanFactory以及它的各種繼承層級的接口、抽象類及實現類&#xff0c;因為內容很多&#xff0c;所以這里不介紹ApplicationContext繼承體系下的類&#xff08;雖然ApplicationContext本質上也是BeanFactory&#xff0c;但是畢竟這這是我們平時接觸最多的兩種類別&a…

deepin15.7掛載/home到單獨的分區:

1、首先打開Gpart分區編輯器&#xff0c;找一個空閑的分區&#xff0c;調整好分區大小&#xff0c;格式化成ext4格式。 具體步驟為首先unmount所用到的盤&#xff0c;然后右擊該盤選擇format to ext4&#xff0c;最后點擊apply提交修改 2、記錄下分區的路徑&#xff0c;比如 /d…