分割字符串
来源:互联网 发布:哪里算八字准 知乎 编辑:程序博客网 时间:2024/06/05 06:58
题目描述
一个字符串X被称为Y的anagram串,如果X是由Y的字符重新排序构成,不能移除或添加字符。比如”baba”, “abab”, “aabb”和”abba”是”aabb”的anagram串, “aaab”,”aab”和”aabc”则不是。
一个字符串X被称为Y的子串,如果X是从Y串中移除一些字符(0个字符也可以),并且剩下字符的顺序不变。比如”ac”,”abd”,”abcd”是”abcd”的子串,”ca”,”abb”,”abcde”则不是。
那么,一个字符串X称为Y的anagram子串,当且仅当存在一个字符串Z,X是Z的anagram串,Z是Y的子串。
对于一个长串S,罗老师想把他们分割成s1,s2,…,sn,也就是n个字符串,满足,当s1,s2,…,sn连接起来的时候刚好是S,同时,si是si+1的anagram子串(0
#include<cstdio>#include<cstring>#include<iostream>#include<cmath>#include<algorithm>#define inf 100000000#define ll long long#define mo 1000000007using namespace std;char ch[505];int dp[505][505],sum[505][27],a[505];bool flag[505][505];int n;inline int read(){ int x=0,f=1;char ch=getchar(); while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();} while (ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar(); return x*f;}bool check(int l,int i,int r)请无视此过程{ bool flag=1; for (int k=1;k<=26;k++) if (sum[i][k]-sum[l-1][k]>sum[r][k]-sum[i][k]){flag=0;break;} return flag;}int dfs(int l,int r){ if (l==1) return 1; if (dp[l][r]!=-1) return dp[l][r]; dp[l][r]=-inf;!//改了好久 for (int i=l-1;i;i--) if (sum[r][a[i]]-sum[l-1][a[i]]>=sum[l-1][a[i]]-sum[i-1][a[i]]) dp[l][r]=max(dfs(i,l-1)+1,dp[l][r]); else break; return dp[l][r];}.int main(){ scanf("%s",ch+1); n=strlen(ch+1); for (int i=1;i<=n;i++) { a[i]=ch[i]-'A'+1; sum[i][ch[i]-'A'+1]++; for (int j=1;j<=26;j++) sum[i][j]+=sum[i-1][j]; for (int j=i;j<=n;j++) dp[i][j]=-1; } int ans=0; for (int i=n;i;i--) { ans=max(dfs(i,n),ans); } cout<<ans; return 0;}
阅读全文
0 0
- 分割字符串
- 分割字符串
- 分割字符串
- 分割字符串
- 分割字符串
- 字符串分割
- 字符串分割
- 分割字符串
- 字符串分割
- 字符串分割
- 分割字符串
- 分割字符串
- 分割字符串
- 字符串分割
- 分割字符串
- 字符串分割
- 字符串分割
- 分割字符串
- 实现手机左右滑屏效果
- 2017暑期实习面经分享(大数据&Java&后台)
- c++---回文数
- Tornado——一个异步web服务器
- Java首选项Preferences
- 分割字符串
- oracle提示TNS:无监听程序的解决办法
- 线段数总结
- 简单测试--C#实现中文汉字转拼音首字母
- elasticsearch添加mapping
- 双向链表
- 分词学习(3),基于ngram语言模型的n元分词
- 1160-蛇形矩阵
- 笔记本风扇控制程序,支持蓝天模具笔记本