[网易]字符串回文分割

简介:

【题目】

将一个很长的字符串,分割成一段一段的子字符串,子字符串都是回文字符串。有回文字符串就输出最长的,没有回文就输出一个一个的字符。
例如:habbafgh
输出h,abba,f,g,h。

【思路一】

基于“最长回文子串算法”求出当前字符串的最长回文子串,就可以分成3部分
a、最长回文子串left部分
b、最长回文子串
c、最长回文子串right部分

然后分别求a和c的最长回文子串
递归至每部分都成单个字符+当前最长回文子串,就可以分解成最终结果。

【代码一】

#include<string>
#include<iostream>
using namespace std;

// beg end 用于返回最大回文串的范围
void MaxPalindromeNumber(string str,int& beg,int& end){
    int maxLen = 1,start = beg;
    int left,right;
    for(int i = beg;i <= end;i++){
        //奇数字串
        int oddLen = 1;
        left = i-1;
        right = i+1;
        while(left >= beg && right <= end && str[left] == str[right]){
            left--;
            right++;
            oddLen += 2;
        }
        //更新最大长度
        if(oddLen > maxLen){
            maxLen = oddLen;
            //记录当前最大回文串的起始位置
            start = left+1;
        }
        //偶数字串
        left = i;
        right = i+1;
        int evenLen = 0;
        while(left >= beg && right <= end && str[left] == str[right]){
            left--;
            right++;
            evenLen += 2;
        }
        //更新最大长度
        if(evenLen > maxLen){
            maxLen = evenLen;
            //记录当前最大回文串的起始位置
            start = left+1;
        }
    }
    beg = start;
    end = start + maxLen - 1;
}
int index = 0;
void SpilitPalindromeNumber(string str,int& beg,int& end){
    int lbeg = beg;
    int rend = end;
    //beg end 返回当前最大回文串的起始点和截止点
    MaxPalindromeNumber(str,beg,end);
    int lend = beg - 1;
    int rbeg = end + 1;
    // lbeg lend 最大回文串的左部
    // rbeg rend 最大回文串的右部
    if(lbeg <= lend){
        SpilitPalindromeNumber(str,lbeg,lend);
    }
    //控制格式输出
    if(index == 0){
        cout<<str.substr(beg,end-beg+1);
        index++;
    }
    else{
        cout<<","<<str.substr(beg,end-beg+1);
        index++;
    }
    if(rbeg <= rend){
        SpilitPalindromeNumber(str,rbeg,rend);
    }
}

int main(){
	string str="djdslkAABCDEAfjdl1234321skjflkdsjfkldsababasdlkfjsdwieowowwpw";
	int beg = 0;
	int end = str.length()-1;
	SpilitPalindromeNumber(str,beg,end);
	return 0;
}

【思路二】

先将给定字符串翻转,然后和原来的字符串一起,这样就变成了最长公共子序列问题。
此时可以利用动态规划的思路来完成。
关于最长公共子序列问题可以参考<算法导论>里面有详细的说明





相关链接:

[百度]2014百度校园招聘之最长回文串

[小米]2015小米校招之回文数判断

目录
相关文章
|
9月前
|
数据可视化 小程序 定位技术
腾讯位置 - 产品介绍(结尾附源码)
腾讯位置 - 产品介绍(结尾附源码)
44 0
|
11月前
|
自然语言处理 搜索推荐 数据处理
首个基于交互式网页搜索的中文问答开源框架,清华、人大、腾讯联合发布WebCPM
首个基于交互式网页搜索的中文问答开源框架,清华、人大、腾讯联合发布WebCPM
|
11月前
|
机器学习/深度学习 数据可视化 数据库
Kaggle第一人 | 详细解读2021Google地标识别第一名解决方案(建议全文背诵)(二)
Kaggle第一人 | 详细解读2021Google地标识别第一名解决方案(建议全文背诵)(二)
105 0
|
11月前
|
机器学习/深度学习 算法 PyTorch
Kaggle第一人 | 详细解读2021Google地标识别第一名解决方案(建议全文背诵)(一)
Kaggle第一人 | 详细解读2021Google地标识别第一名解决方案(建议全文背诵)(一)
213 0
|
11月前
|
人工智能 自然语言处理 数据可视化
ACL 2022 | 提升支付宝搜索体验,蚂蚁、北大提出基于层次化对比学习的文本生成框架
ACL 2022 | 提升支付宝搜索体验,蚂蚁、北大提出基于层次化对比学习的文本生成框架
178 0
|
11月前
|
机器学习/深度学习 人工智能 自然语言处理
检索速度提高八倍,字节跳动发布最新音乐检索系统ByteCover2(2)
检索速度提高八倍,字节跳动发布最新音乐检索系统ByteCover2
|
11月前
|
机器学习/深度学习 数据可视化 数据挖掘
检索速度提高八倍,字节跳动发布最新音乐检索系统ByteCover2(1)
检索速度提高八倍,字节跳动发布最新音乐检索系统ByteCover2
检索速度提高八倍,字节跳动发布最新音乐检索系统ByteCover2(1)
|
11月前
|
自然语言处理 搜索推荐
4款「ChatGPT搜索」全面对比!斯坦福华人博士纯手工标注:新必应流畅度最低,近一半句子都没引用
4款「ChatGPT搜索」全面对比!斯坦福华人博士纯手工标注:新必应流畅度最低,近一半句子都没引用
210 0
|
自然语言处理 分布式计算 Scala
使用Spark实现微博内容解析-每月前十最热词汇
简单spark+scala的demo,具体为map,flatmap,reducebykey等算子的运用
179 0
|
数据采集 JSON 安全
竟然如此简单!输入明星名字就可以直接爬取高清图片
**听说你在自己喜欢的明星壁纸?比如李易峰,王一博,易烊千玺、王源、王俊凯,李现等。今天教你批量下载这些明星高清壁纸****(文末有福利)**
366 0