#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;
}