#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <queue>
#include <stack>
#include <string>
#include <bitset>
#include <cstdio>
#include <limits>
#include <vector>
#include <climits>
#include <cstring>
#include <cstdlib>
#include <fstream>
#include <numeric>
#include <sstream>
#include <iostream>
#include <algorithm>
#include <unordered_map>

using namespace std;


int main(){
    int i, j, n;
    string s;
    int h[26]={}, ans=0;
    for(i=0; i<26; ++i) {
        cin>>h[i];
    }
    while(cin>>s) {
        n=s.length();
        int cur=0;
        for(i=0; i<n; ++i) {
            cur=max(cur, h[s[i]-'a']);
        }
        ans+=cur*n;
    }
    cout<<ans;
    return 0;
}