题解 | nico和niconiconi

nico和niconiconi

https://www.nowcoder.com/practice/70a03345bae6499ea4338ebc3a0b60e9

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

typedef long long ll;

// 检查从位置start开始的子串是否等于pattern
bool check(const string& s, int start, const string& pattern) {
    for (size_t i = 0; i < pattern.size(); i++) {
        if (s[start + i] != pattern[i]) return false;
    }
    return true;
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    
    int n;
    ll a, b, c;
    string s;
    cin >> n >> a >> b >> c >> s;
    
    vector<ll> dp(n + 1, 0);
    
    for (int i = 0; i <= n; i++) {
        if (i > 0) {
            dp[i] = max(dp[i], dp[i - 1]);
        }
        
        // 向前看,检查从当前位置开始的匹配
        if (i + 4 <= n && check(s, i, "nico")) {
            dp[i + 4] = max(dp[i + 4], dp[i] + a);
        }
        if (i + 6 <= n && check(s, i, "niconi")) {
            dp[i + 6] = max(dp[i + 6], dp[i] + b);
        }
        if (i + 10 <= n && check(s, i, "niconiconi")) {
            dp[i + 10] = max(dp[i + 10], dp[i] + c);
        }
    }
    
    cout << dp[n] << "\n";
    
    return 0;
}

全部评论

相关推荐

白火同学:1、简历可以浓缩成一页,简历简历先要“简”方便HR快速过滤出有效信息,再要“历”用有效信息突出个人的含金量。 2、教育背景少了入学时间~毕业时间,HR判断不出你是否为应届生。 3、如果你的平台账号效果还不错,可以把账号超链接或者用户名贴到对应位置,一是方便HR知道你是具体做了什么内容的运营,看到账号一目了然,二是口说无凭,账号为证,这更有说服力。
面试被问期望薪资时该如何...
点赞 评论 收藏
分享
牛客96931767...:这履历不是在网安横着走啊
大家都开始春招面试了吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务