关注
先说结论,动态规划,时间复杂度最差为O(n3)。
递推公式为dp[i][j] = str[ dp[i][j-1] +j-i+1 ] ==
str[j]?dp[i][j-1]:dp[dp[i][j-1]]
递推公式优点难懂,举个例子:
abcab
设数组dp[len][len],其中dp[i][j]表示 上一个str[i,j]的开始位置
初始化:因为str[0,0] = a,之前没出现过,dp[0][0] = -1
同理str[1,1] = -1,dp[2][2] = -1,
因为str[3,3] = a,上一次出现的位置为0,因此dp[3][3] = 0
因为str[4,4] = b,上一次出现的位置为1,因此dp[4][4] = 1.
#include <iostream>
#include <vector>
#include <map>
using namespace std;
void getAllSub(const string str){
const int len = str.length();
map<char,int> mymap;
vector<vector<int>>
myvec(len,vector<int>(len,-1));
for(int i =0;i<len;i++){
if(mymap.count(str[i]) == 0){
mymap[str[i]] = i;
}else{
myvec[i][i] = mymap[str[i]];
mymap[str[i]] = i;
}
}
for(int i =0;i<len;i++)
for(int j =i;j<len;j++){
if(i == j){
if(myvec[i][j] != -1 &&
myvec[myvec[i][j]][myvec[i][j]] == -1)
cout<<str.substr(i,1)<<endl;
continue;
}
int tmp = myvec[i][j-1];
while(tmp != -1){
if(str[j] == str[tmp+j-i]){
myvec[i][j] = tmp;
if(myvec[tmp][tmp+j-i-1] == -1)
cout<<str.substr(i,j-i+1)<<endl;
break;
}else tmp = myvec[tmp][tmp+j-i-1];
}
}
}
int main()
{
getAllSub("ababa");
return 0;
}
查看原帖
点赞 评论
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 你最近因为什么迷茫? #
12315次浏览 191人参与
# AI coding的好用工具分享 #
3765次浏览 104人参与
# 上班以后,你还有哪些坚持的爱好? #
1850次浏览 53人参与
# 实习怎么做才有更好的产出 #
2494次浏览 77人参与
# 你都在哪些场所面过试? #
4763次浏览 81人参与
# 实习生工资多少才算正常? #
3987次浏览 86人参与
# 实习心态崩了 #
100624次浏览 515人参与
# 你给AI提过哪些离谱的需求? #
1834次浏览 73人参与
# 找工作以来,你最看不惯__ #
3073次浏览 73人参与
# 领导做过最不靠谱的事 #
5077次浏览 87人参与
# 哪些公司开春招了? #
2073次浏览 29人参与
# 你最希望上岸的公司是? #
181578次浏览 800人参与
# 华为保温 #
169780次浏览 643人参与
# 你觉得第一学历对求职有影响吗? #
222341次浏览 1230人参与
# 刚入职就____,这样正常吗? #
124584次浏览 665人参与
# 秋招有哪些公司要求提前实习 #
102960次浏览 545人参与
# 非技术岗投递进展 #
166691次浏览 1317人参与
# 新年的第一句祝福 #
53655次浏览 389人参与
# 华子oc时间线 #
1408433次浏览 6994人参与
# 当发现同事想辞职 #
13658次浏览 47人参与
查看30道真题和解析