日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

拆分字符串使唯一子字符串的数目最大

發布時間:2024/4/18 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 拆分字符串使唯一子字符串的数目最大 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

思路:

方法一:回溯

拆分給定的字符串,要求拆分后的每個子字符串唯一,求子字符串的最大數目,可以通過回溯算法實現。

對于長度為 n的字符串,有n?1個拆分點。從左到右遍歷字符串,對于每個拆分點,如果在此拆分之后,新得到的一個非空子字符串(即拆分點左側的最后一個被拆分出的非空子字符串)與之前拆分出的非空子字符串都不相同,則當前的拆分點可以進行拆分,然后繼續對剩下的部分(即拆分點右側的部分)進行拆分。

判斷拆分出的非空子字符串是否有重復時,可以使用哈希表。

當整個字符串拆分完畢時,計算拆分得到的非空子字符串的數目,并更新最大數目

class Solution { public:unordered_set<string> set;int maxCount;void dfs(string s,int count,int startIndex){if(startIndex>=s.size()){maxCount=max(maxCount,count);return;}for(int ii=startIndex;ii<s.size();ii++){string sub=s.substr(startIndex,ii-startIndex+1);if(set.find(sub)==set.end()){set.insert(sub);dfs(s,count+1,ii+1);set.erase(sub);}}}int maxUniqueSplit(string s) {maxCount=1;dfs(s,0,0);return maxCount;} };

可能的變型一:

總結

以上是生活随笔為你收集整理的拆分字符串使唯一子字符串的数目最大的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。