算法:字符串消除問題的數學證明

問題:

給定一個字符串,僅由A、B、C3個字母組成。當出現連續兩個不同的字母時,你可以用另外一個字母替換它,如有AB或BA連續出現,你把它們替換為字母C;有AC或CA連續出現時,你可以把它們替換為字母B;有BC或CB連續出現時,你可以把它們替換為字母A。可以不斷反復按照這個規則進行替換,目標是使得最終結果所得到的字符串盡可能短,求最終結果的最短長度。

輸入:字符串。長度不超過200,僅由ABC3個字母組成。 輸出:按照上述規則不斷消除替換,所得到的字符串最短的長度。

?

例如:

輸入CAB,輸出2。因為我們可以把它變為BB或者變為CC。

輸入BCAB,輸出1。我們可以把它變為AAB到AC到B,也可以把它變為BBB,但因為前者長度更短,所以輸出1。

?

?

?

先給出幾個概念

純字符串:只含有一種字母的字符串稱為純字符串,例如AAA就是一個純字符串

混字符串:含有至少兩種字母的字符串稱為混字符串,例如ABC就是一個混字符串

最優長度:字符串通過消除的最終結果的最短長度,稱為該字符串的最優長度。上面的示例中,CAB的最優長度為2,BCAB的最優長度為1

最優串:字符串通過消除達到最優長度時的字符串稱為最優串最優串可能不止一個。如CAB的最優串為BB和CC,而BCAB的最優串為B。最優串一定是純字符串

統計向量:用(X,Y,Z)表示字符串的統計向量,其中X、Y、Z分別表示字符串中字母A、B、C的個數。上面的示例中,CAB的統計向量為(1,1,1),BCAB的統計向量為(1,2,1)

統計特征向量:用(X,Y,Z)表示字符串的統計特征向量,其中X、Y、Z分別表示字符串中字母A、B、C的個數的奇偶性,用“奇”、“偶”表示。CAB的統計特征向量為(奇,奇,奇),BCAB的統計特征向量為(奇,偶,奇)

?

?

?

再給出幾個推論

推論1純字符串最優長度就是純字符串的長度。

很明顯的,只有一個字母,沒法消除,所以最優長度就是純字符串的長度

?

推論2:在純字符串前或后加另一個字母得到新的混字符串,則新混字符串最優長度為1

例如:BBBBBBBA。則消除的過程是,BBBBBBBA >> BBBBBBC >> BBBBBA >> BBBBC >> BBBA >> BBC >> BA >> C

其他的類似,不再贅述

?

推論3:若純字符串的長度為偶數,則在前或后添加另一個字母得到新的混字符串,則新混字符串最優串為添加的字母;若純字符串的長度為奇數,則新混字符串最優串為剩下的一個字母

假設純字符串為BB,添加字母A,則新混字符串為BBA,BBA >> BC >> A

假設純字符串為BBBB,添加字母A,則新混字符串為BBBBA,BBBBA >> BBA >> A

以此類推,推論3的前半部得證

假設純字符串為B,添加字母A,則新混字符串為BA,BA >> C

假設純字符串為BBB,添加字母A,則新混字符串為BBBA,BBBA >> BA >> C

以此類推,推論3的后半部得證

?

推論4混字符串最優長度不超過2(為1或2)

證明:

首先混字符串通過不停的消除,最終能得到一個純字符串(因為若還有不同的字母,則必相鄰,則還能繼續消除)。

若該純字符串的長度為1或2,則證明了該推論(不過,就算純字符串長度為2,還沒證明最優長度一定是2,可以肯定的是最優長度不超過2,即1或2都有可能)

若該純字符串的長度大于2,不失一般性,假設該純字符串的長度為K(K>2),該純字符串都由字母B組成(字母A、C是一樣的),該純字符串是通過N(N≥1)步消除得到的

那么回退一步,第N-1步消除得到的混字符串為B……BACB……B,其中A前面有K1個B,C后面有K2個B,K1+K2=K-1。(也有可能是B……BCAB……B,和B……BACB……B是一致的,不再贅述了)

那么,根據K1和K2的取值不同,可以優化出不同的消除

K1是奇數,K2是奇數。利用推論3,可知B……BA >> C;CB……B >> A;B……BACB……B >> CA >> B,最優串是B,最優長度為1

K1是奇數,K2是偶數。利用推論3,可知B……BA >> C;CB……B >> C;B……BACB……B >> CC,則最優長度不超過2(因為還沒法證明最優長度不會是1)

K1是偶數,K2是奇數。利用推論3,可知B……BA >> A;CB……B >> A;B……BACB……B >> AA,則最優長度不超過2(因為還沒法證明最優長度不會是1)

K1是偶數,K2是偶數。利用推論3,可知B……BA >> A;CB……B >> C;B……BACB……B >> AC >> B,最優串是B,最優長度為1

綜上所述,混字符串最優長度不超過2

?

推論5統計特征向量為(奇,奇,奇)或(偶,偶,偶)的混字符串最優長度為2;其余的混字符串最優長度為1

證明:

考察一下,每次消除,統計特征向量的變化過程

?

假設字符串的統計特征向量為(奇,奇,奇)

假設消除是AC(或CA) >> B,則A和C的個數減1,而B的個數增加1,則統計特征向量變為(偶,偶,偶)

假設消除是AB(或BA) >> C,則A和B的個數減1,而C的個數增加1,則統計特征向量變為(偶,偶,偶)

假設消除是BC(或CB) >> A,則B和C的個數減1,而A的個數增加1,則統計特征向量變為(偶,偶,偶)

綜上所述,統計特征向量為(奇,奇,奇)的混字符串,經過1次消除后,統計特征向量變為(偶,偶,偶)

同理可證,統計特征向量為(偶,偶,偶)的混字符串,經過1次消除后,統計特征向量變為(奇,奇,奇)

由此可知,反復消除后,統計特征向量為(奇,奇,奇)的混字符串最優串統計特征向量是(偶,偶,偶)。(因為最優串純字符串,只能有1種字符,所以最優串不可能是(奇,奇,奇))

同理可證,統計特征向量為(偶,偶,偶)的混字符串最優串統計特征向量也是(偶,偶,偶)。

因此,統計特征向量為(奇,奇,奇)或(偶,偶,偶)的混字符串最優串統計特征向量為(偶,偶,偶)

?

假設字符串的統計特征向量為(奇,偶,偶)

假設消除是AC(或CA) >> B,則A和C的個數減1,而B的個數增加1,則統計特征向量變為(偶,奇,奇)

假設消除是AB(或BA) >> C,則A和B的個數減1,而C的個數增加1,則統計特征向量變為(偶,奇,奇)

假設消除是BC(或CB) >> A,則B和C的個數減1,而A的個數增加1,則統計特征向量變為(偶,奇,奇)

綜上所述,統計特征向量為(奇,偶,偶)的混字符串,經過1次消除后,統計特征向量變為(偶,奇,奇)

同理可證,統計特征向量為(偶,奇,奇)的混字符串,經過1次消除后,統計特征向量變為(奇,偶,偶)

由此可知,反復消除后,統計特征向量為(奇,偶,偶)的混字符串最優串統計特征向量是(奇,偶,偶)。(因為最優串純字符串,只能有1種字符,所以最優串不可能是(偶,奇,奇))

同理可證,統計特征向量為(偶,奇,奇)的混字符串最優串統計特征向量也是(奇,偶,偶)。

因此,統計特征向量為(奇,偶,偶)或(偶,奇,奇)的混字符串最優串統計特征向量為(奇,偶,偶)

?

同理可證

統計特征向量為(偶,奇,偶)或(奇,偶,奇)的混字符串最優串統計特征向量為(偶,奇,偶)

統計特征向量為(偶,偶,奇)或(奇,奇,偶)的混字符串最優串統計特征向量為(偶,偶,奇)

?

由推論4可知,混字符串最優長度不超過2

如果,混字符串最優長度為1,則最優串是A,統計特征向量是(奇,偶,偶);是B,統計特征向量是(偶,奇,偶);是C,統計特征向量是(偶,偶,奇)

如果,混字符串最優長度為2,則最優串是AA或BB或CC,統計特征向量是(偶,偶,偶)

?

所以,統計特征向量為(奇,奇,奇)或(偶,偶,偶)的混字符串最優長度是2。

統計特征向量為(奇,偶,偶)或(偶,奇,奇)的混字符串最優長度為1,最優串是A

統計特征向量為(偶,奇,偶)或(奇,偶,奇)的混字符串最優長度為1,最優串是B

統計特征向量為(偶,偶,奇)或(奇,奇,偶)的混字符串最優長度為1,最優串是C

?

證明完畢

?

?

結論:

1、純字符串最優串就是自身,最優長度就是自身的長度

2、統計特征向量為(奇,奇,奇)或(偶,偶,偶)的混字符串最優長度為2

3、其余的混字符串最優長度是1,其中統計特征向量為(奇,偶,偶)或(偶,奇,奇)的混字符串最優串是A;統計特征向量為(偶,奇,偶)或(奇,偶,奇)的混字符串最優串是B;統計特征向量為(偶,偶,奇)或(奇,奇,偶)的混字符串最優串是C


? ? 本文轉自萬倉一黍博客園博客,原文鏈接:http://www.cnblogs.com/grenet/p/3300591.html,如需轉載請自行聯系原作者



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

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

相關文章

學習筆記(57):Python實戰編程-Treeview

立即學習:https://edu.csdn.net/course/play/19711/343120?utm_sourceblogtoedu 1.樹狀結構Treeview:分為樹狀折疊式列表和列表顯示,是一種很重要數據列表展示的形式 2.樹狀列表建立步驟: 1)創建一個樹狀列表:在這里可以設置顯示…

ios 常用操作-1

項目中可能會用到的一些技巧方法,做個記錄,已被不時之需。 一。程序在運行過程中不鎖屏? [UIApplication sharedApplication].idleTimerDisabledYES; 二。顯示被view 或 control遮蓋的背景內容。比如有時在不同的ios版本上 tableview cell上畫…

(視覺和激光傳感器)SLAM 做室內GPS與室外真實GPS在無人機上的對比

1、室外無人機GPS的作用 1)記錄實時無人機起飛點與當前飛行無人機的絕對位置關系,顯示當面無人機離起飛點的真實距離 2)做室外無人機懸停的功能,使用GPS當前點與懸停點GPS經緯度做對比 3)無人機上層應用&#xff0c…

C# 連接 Oracle 的幾種方式

C# 連接 Oracle 的幾種方式 一:通過System.Data.OracleClient(需要安裝Oracle客戶端并配置tnsnames.ora)1. 添加命名空間System.Data.OracleClient引用2. using System.Data.OracleClient;3. string connString "User IDIFSAPP;PasswordIFSAPP;Data SourceRAC…

驗證VSPHERE5 支持大于2TB磁盤

VSPHERE5 使用GTP格式的分區表,文件系統類型為VMFS5.X,直接支持大于2TB的磁盤分區,相對于VSPHERE4不同 vsphere4使用MSDOS格式的分區表,文件系統類型為VMFS3.X 而vsphere5 block塊大小統一為1MB,而不是vsphere4的多種格…

學習筆記(58):Python實戰編程-Combobox

立即學習:https://edu.csdn.net/course/play/19711/343121?utm_sourceblogtoedu 1.下拉列表Combobox:與Listbox相比,下拉列表是一次只是顯示一項內容,適用于布局緊張的情況下,而Listbox則是將所有的內容鋪開來展示 2.關鍵代碼 1&#xff09…

Java Inner Class 內部類

內部類 Inner Class 一個內部類可以定義在另一個類里,可以定義在函數里,甚至可以作為一個表達式的一部分。 Java中的內部類共分為四種: 靜態內部類static inner class (also called nested class) 成員內部類member inner class 局部內部類l…

SLAM系統工程,常用數據集下載鏈接(TUM KITTI DSO Mono EuRoC)

TUM 鏈接:https://pan.baidu.com/s/1nwXtGqH 密碼:lsgr KITTI 鏈接:https://pan.baidu.com/s/1htFmXDE 密碼:uu20 DSO 鏈接:https://pan.baidu.com/s/1eSRmeZK 密碼:6x5b Mono 鏈接:http…

uva1331三角剖分

題意&#xff1a;輸入一個簡單m&#xff08;2<m<50)邊形&#xff0c;找到一個最大三角形最小的三角剖分&#xff08;用不相交的對角線把一個多邊形分成若干個三角形&#xff09;。輸出最大的三角形面積。 分析&#xff1a;每條對角線都是無序的&#xff0c;因此&#xff…

Halcon算子翻譯——default

名稱 default - switch段中的備用分支。 用法 default( : : : ) 描述 default在switch段中開放備用分支。 如果switch語句的控制表達式的計算結果不匹配前面的case語句的任何整數常量&#xff0c;則訪問該分支。 結果 default&#xff08;作為算子&#xff09;總是返回2&#x…

現代制造工程筆記01:課程安排

電子教材&#xff1a;http://www.bookask.com/read/4588.html

(轉).gitignore詳解

本文轉自http://sentsin.com/web/666.html 今天講講Git中非常重要的一個文件——.gitignore。 首先要強調一點&#xff0c;這個文件的完整文件名就是“.gitignore”&#xff0c;注意最前面有個“.”。這樣沒有擴展名的文件在Windows下不太好創建&#xff0c;這里給出win7的創建…

Effective Java 英文 第二版 讀書筆記 Item 14:In public classes,use accessor methods,not public fields...

本章主要分析 公開屬性與私有屬性提供公開get、set方法兩種方式對比 // Degenerate classes like this should not be public! class Point { public double x; public double y; } // Public class with exposed immutable fields - questionable public final class Time { …

22個值得收藏的android開源碼-UI篇

本文介紹了android開發人員中比較熱門的開源碼&#xff0c;這些代碼絕大多數能夠直接應用到項目中。FileBrowserView 一個強大的文件選擇控件。界面比較美麗&#xff0c;使用也非常easy。 特點&#xff1a;能夠自己定義UI&#xff1b;支持復制、剪切、刪除、移動文件&#xff1…

現代制造工程02:第一部分——刀具(含2個易考點)

一、金屬切削原理 可以看出哪些性能參數是同向性得&#xff0c;并且知道性能參數與三要素有什么關系 易考點&#xff1a;三個變形區 易考點&#xff1a;磨損種類以及磨損階段、磨頓標準

Fortran向C傳遞NULL值

在很多C或C的頭文件定義中&#xff0c;NULL被指定定義為0&#xff0c;這里不再具體展開 gfortran的手冊關于iso c binding的章節&#xff0c;定義NULL如下 Moreover, the following two named constants are defined: NameType C_NULL_PTRC_PTRC_NULL_FUNPTRC_FUNPTRBoth are e…

視覺slam重點知識筆記

1、除了基本矩陣和本質矩陣&#xff0c;我們還有一種稱為單應矩陣&#xff08;Homography&#xff09;H 的東西&#xff0c;它 描述了兩個平面之間的映射關系。若場景中的特征點都落在同一平面上&#xff08;比如墻&#xff0c;地面等&#xff09;&#xff0c;則可以通過單應性…

iOS開發之share第三方登錄以及分享

&#xff08;1&#xff09;官方下載ShareSDK iOS 2.8.8&#xff0c;地址&#xff1a;http://sharesdk.cn/ &#xff08;2&#xff09;根據實際情況&#xff0c;引入相關的庫&#xff0c;參考官方文檔。 &#xff08;3&#xff09;在項目的AppDelegate中一般情況下有三個操作&am…

Linux磁盤的劃分

磁盤的組成&#xff1a; 磁道&#xff1a;track 扇區&#xff1a;sector (512字節) 磁頭&#xff1a;head 柱面&#xff1a;cylinder MBR/msdos 分區模式 1--4個主分區&#xff0c;或者0--3個主分區加1個擴展分區&#xff08;n個邏輯分區&#xff09; 最大支持容量為2.2TB的磁…