题解 | #密码截取#

密码截取

https://www.nowcoder.com/practice/3cd4621963e8454594f00199f4536bb1

#include <iostream>
#include <vector>
#include <cmath>
using namespace std;

int main() {
    string s;
    int res = 1;
    cin >> s;
    int n = s.size();
    // 代表以下标为n结尾的码串的最长有效密码传长度
    vector<vector<int>> dp(n, vector<int>(2, 1));
    // [i][0]代表有效密码串不完全相同的情况,[i][1]代表有效密码串完全相同的情况


    for (int i = 1; i < n; i++) {
        if (s[i] == s[i - 1]) {
            dp[i][1] = dp[i - 1][1] + 1;
            res = max(res, dp[i][1]);
        } else {
            int tmp1 = 1, tmp2 = 1;
            if (i - 1 - dp[i - 1][1] >= 0 && s[i] == s[i - 1 - dp[i - 1][1]]) {
                tmp1 = dp[i - 1][1] + 2;
            }
            if (i - 1 - dp[i - 1][0] >= 0 && s[i] == s[i - 1 - dp[i - 1][0]]) {
                tmp2 = dp[i - 1][0] + 2;
            }
            dp[i][0] = max(tmp1,tmp2);
            res = max(res, dp[i][0]);
        }
    }
    cout << res << endl;
    return 0;
}
// 64 位输出请用 printf("%lld")

动态规划的核心是定义过程量 以及 考虑过程量之间的关系。

本题对于对称 分成了全部相同和 非全部相同两种情况进行考虑, 并考虑了他们之间的关系。

全部评论

相关推荐

牛客263158796号:我领羊一面后十天不挂也不推进 今天问hr说等前序的第一批意向发完看情况再看是否推进
点赞 评论 收藏
分享
10-14 23:01
已编辑
中国地质大学(武汉) Java
CUG芝士圈:虽然是网上的项目,但最好还是包装一下,然后现在大部分公司都在忙校招,十月底、十一月初会好找一些。最后,boss才沟通100家,别焦虑,我去年暑假找第一段实习的时候沟通了500➕才有面试,校友加油
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务