#pragma GCC target("avx2") #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #include using namespace std; #include using namespace atcoder; typedef long long ll; typedef long double ld; #define REP(i, n) for (int i = 0; i < (n); ++i) #define REPR(i, n) for (int i = n - 1; i >= 0; --i) #define FOR(i, m, n) for (int i = m; i < n; ++i) #define FORR(i, m, n) for (int i = m; i >= n; --i) #define ALL(v) (v).begin(),(v).end() #define ALLR(v) (v).rbegin(),(v).rend() #define SORT(v) sort(ALL(v)) #define RSORT(v) sort(ALLR(v)) #define REV(v) reverse(ALL(v)) #define UNIQUE(x) SORT(x), x.erase(unique(ALL(x)), x.end()) #define fi first #define se second #define PB push_back #define EB emplace_back using pii = pair; using pll = pair; template using vc = vector; template using vvc = vector>; template using vvvc = vector>; using vi = vc; using vl = vc; using vpi = vc; using vpl = vc; // noimi #define INT(...) int __VA_ARGS__;IN(__VA_ARGS__) #define LL(...) ll __VA_ARGS__;IN(__VA_ARGS__) #define STR(...) string __VA_ARGS__;IN(__VA_ARGS__) #define DBL(...) double __VA_ARGS__;IN(__VA_ARGS__) #define VEC(type, name, size) vector name(size);IN(name) #define VEC2(type, name1, name2, size) vector name1(size), name2(size);for(int i = 0; i < size; i++) IN(name1[i], name2[i]) #define VEC3(type, name1, name2, name3, size) vector name1(size), name2(size), name3(size);for(int i = 0; i < size; i++) IN(name1[i], name2[i], name3[i]) #define VEC4(type, name1, name2, name3, name4, size) vector name1(size), name2(size), name3(size), name4(size); for(int i = 0; i < size; i++) IN(name1[i], name2[i], name3[i], name4[i]); #define VV(type, name, h, w) vector> name(h, vector(w));IN(name) int scan() { return getchar(); } void scan(int &a) { cin >> a; } void scan(long long &a) { cin >> a; } void scan(char &a) { cin >> a; } void scan(double &a) { cin >> a; } void scan(string &a) { cin >> a; } template void scan(pair &p) { scan(p.first), scan(p.second); } template void scan(vector &); template void scan(vector &a) {for(auto &i : a) scan(i);} template void scan(T &a) { cin >> a; } void IN() {} template void IN(Head &head, Tail &...tail) {scan(head);IN(tail...);} // tute7627 template using PQ = priority_queue; template using QP = priority_queue,greater>; templatevoid stout(const T &v,ll h,ll w){for(ll i=0;ivoid stout(const T &v,ll n){for(ll i=0;ivoid stout(const vector&v){stout(v,v.size());} templatevoid stout(const vector>&v){for(auto &vv:v)stout(vv,vv.size());} templatevoid debug(const T &v,ll h,ll w){for(ll i=0;ivoid debug(const T &v,ll n){for(ll i=0;ivoid debug(const vector&v){debug(v,v.size());} templatevoid debug(const vector>&v){for(auto &vv:v)debug(vv,vv.size());} templatevoid debug(stack st){while(!st.empty()){cerr<void debug(queue st){while(!st.empty()){cerr<void debug(deque st){while(!st.empty()){cerr<void debug(PQ st){while(!st.empty()){cerr<void debug(QP st){while(!st.empty()){cerr<void debug(const set&v){for(auto z:v)cerr<void debug(const multiset&v){for(auto z:v)cerr<void debug(const array &a){for(auto z:a)cerr<void debug(const map&v){for(auto z:v)cerr<<"["<void OUT(Head&& head, Tail&&... tail){cout << head;if(sizeof...(tail)) cout << " ";OUT(move(tail)...);} void ERR() {cerr << endl;} template void ERR(Head&& head, Tail&&... tail){cerr << head;if(sizeof...(tail)) cerr << " ";ERR(move(tail)...);} void fsp(int n){cout << fixed << setprecision(n);} templatebool chmax(T &a, const T &b) { if (abool chmin(T &a, const T &b) { if (b s(n); vl c(n); vector sm(n,vector(3,vector(81,0))); REP(i,n){ IN(s[i],c[i]); REP(j,s[i].size()){ sm[i][0][j+1]+=sm[i][0][j]+(s[i][j]=='J'); sm[i][1][j+1]+=sm[i][1][j]+(s[i][j]=='O'); sm[i][2][j+1]+=sm[i][2][j]+(s[i][j]=='I'); } } vl J(k+1,INF),O(k+1,INF),I(k+1,INF); J[0]=0; REP(i,k){ REP(j,n){ chmin(J[min(k,i+sm[j][0][s[j].size()])],J[i]+c[j]); } // debug(J); } REP(i,n){ REP(j,s[i].size()+1){ for(int l=k-sm[i][0][j];l<=k;l++){ chmin(O[min(k,sm[i][1][s[i].size()]-sm[i][1][j])],J[max(0,l)]+c[i]); } FOR(m,j+1,s[i].size()){ if(sm[i][1][m]-sm[i][1][j]>=k){ for(int l=k-sm[i][0][j];l<=k;l++){ chmin(I[min(k,sm[i][2][s[i].size()]-sm[i][2][m])],J[max(0,l)]+c[i]); } } } } } chmin(O[0],J[k]); REP(i,k){ REP(j,n){ chmin(O[min(k,i+sm[j][1][s[j].size()])],O[i]+c[j]); } } REP(i,n){ REP(j,s[i].size()+1){ for(int l=k-sm[i][1][j];l<=k;l++){ chmin(I[min(k,sm[i][2][s[i].size()]-sm[i][2][j])],O[max(0,l)]+c[i]); } } } chmin(I[0],O[k]); // debug(I); REP(i,k){ REP(j,n){ chmin(I[min(k,i+sm[j][2][s[j].size()])],I[i]+c[j]); } // debug(I); } // debug(J); // debug(O); // debug(I); if(O[k]==INF) OUT(-1); else OUT(I[k]); }