IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 洛谷PP2031 脑力达人之分割字串【字符串DP】【黄】 -> 正文阅读

[数据结构与算法]洛谷PP2031 脑力达人之分割字串【字符串DP】【黄】

Date:2022.03.16
题目描述
现在有一个字符串,你可以对这个字符串进行拆分,如 abcvsdaas 可以拆分为 abc|vs|d|aas,现在再给你一个字典,要求分割成的每一个子串必须要有包含其中的任意一个单词。那么最多可以分为几个子串呢?
输入格式
第一行,一行字符串
第二行一个正整数 N,表示字典中字符串的数量
接下来 N 行,每行一个字符串 Ai,表示字典中的一个字符串。
输出格式
一个整数,表示最多的分割数。
输入输出样例
输入 #1复制
asdsd
3
as
sd
ds
输出 #1复制
2
说明/提示
特殊情况:
如果原字符串不能被分割,请输出 0。
数据范围:
对于 20% 的数据,1≤∣s∣≤50,1≤n≤50。
对于 100% 的数据,1≤∣Ai∣≤∣s∣≤300,1≤N≤500。
其中,|s|,|Ai| 表示字符串 s 与 Ai 的长度。

思路①:问题即求出给定串最多包含几个子串,子串是可重复的(例:abab是两个ab),但不可交叉(例:abs,其中不能认定为含ab和bs两个子串)。
f [ i ] : f[i]: f[i]: i i i为结尾的串最多可分出几个子串。
设第 j j j个子串为 z c [ j ] zc[j] zc[j]状态转移方程: f [ i ] = m a x ( f [ i ] , f [ i ? z c [ j ] . l e n g t h ( ) ] + 1 ) f[i]=max(f[i],f[i-zc[j].length()]+1) f[i]=max(f[i],f[i?zc[j].length()]+1)
【 z c [ j ] = = s . s u b s t r ( i ? z c [ j ] . l e n g t h ( ) + 1 , i ) ∧ i > = z c [ j ] . l e n g t h ( ) 】 【zc[j]==s.substr(i-zc[j].length()+1,i) \wedge i>=zc[j].length()】 zc[j]==s.substr(i?zc[j].length()+1,i)i>=zc[j].length()
核心思想:每次找看当前子串是否可作为以 i i i结尾的后缀。
代码如下:

#include <bits/stdc++.h>
#define x first
#define y second
using namespace std;
typedef long long LL;
const LL N = 1010,INF=0x3f3f3f3f3f3f3f3f;
typedef pair<LL, LL> PII;
LL t,n,m,k,f[N];
string zc[N];
int main()
{
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    string ss;cin>>ss;
    string s=" ";s+=ss;
    cin>>n;f[0]=0;
    for(int i=1;i<=n;i++) cin>>zc[i];
    for(int i=1;i<=ss.length();i++)
        for(int j=1;j<=n;j++)
            if(i>=zc[j].length())
            {
                //cout<<zc[j]<<' '<<s.substr(i-zc[j].length()+1,i)<<endl;
                if(zc[j]==s.substr(i-zc[j].length()+1),i)
                    f[i]=max(f[i],f[i-zc[j].length()]+1);
            }
    LL maxx=0;
    for(int i=1;i<ss.length();i++) maxx=max(maxx,f[i]);//找到不同结尾但是最大的
    cout<<maxx;
    return 0;
}

全wa。
思路②:思路①漏了一个非常重要的限制!!!每次判断时 z c [ j ] zc[j] zc[j]的结尾不非是第 i i i个字符!!! z c [ j ] zc[j] zc[j]也可以以 i ? 1 、 . . . 、 z c [ j ] . l e n g t h ( ) i-1、...、zc[j].length() i?1...zc[j].length()作为结尾,即要考虑 f [ z c [ j ] . l e n g t h ( ) , i ? z c [ j ] . l e n g t h ( ) ] f[zc[j].length(),i-zc[j].length()] f[zc[j].length(),i?zc[j].length()]来更新 f [ i ] f[i] f[i];而思路①显然只考虑了以 f [ i ? z c [ j ] . l e n g t h ( ) ] f[i-zc[j].length()] f[i?zc[j].length()]来更新 f [ i ] f[i] f[i]!!!
代码如下:(思路一样,方向反着的)

#include <bits/stdc++.h>
#define x first
#define y second
using namespace std;
typedef long long LL;
const LL N = 2e6+10,INF=0x3f3f3f3f3f3f3f3f;
typedef pair<LL, LL> PII;
LL t,n,m,k,f[N];
string zc[N];
int main()
{
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    string ss;cin>>ss;
    string s=" ";s+=ss;
    cin>>n;f[0]=0;
    for(int i=1;i<=n;i++) cin>>zc[i];
    for(int i=0;i<=ss.length();i++)
        for(int j=1;j<=n;j++)
            if(ss.length()-i>=zc[j].length() && zc[j]==s.substr(i+1,zc[j].length()))
            {
                for(int k=i+zc[j].length();k<=ss.length();k++)
                    f[k]=max(f[k],f[i]+1);
            }
    cout<<f[ss.length()];
    return 0;
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-03-17 22:25:52  更:2022-03-17 22:30:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:30:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码