/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 2ms 540.0 KiB
#2 Accepted 16ms 608.0 KiB
#3 Accepted 697ms 580.0 KiB
#4 Accepted 1136ms 564.0 KiB
#5 Accepted 1126ms 796.0 KiB
#6 Accepted 1139ms 772.0 KiB
#7 Accepted 1136ms 676.0 KiB
#8 Accepted 1149ms 588.0 KiB
#9 Accepted 1203ms 580.0 KiB
#10 Accepted 576ms 560.0 KiB
#11 Accepted 1149ms 776.0 KiB
#12 Accepted 1155ms 772.0 KiB
#13 Accepted 1141ms 776.0 KiB

Code

#include<bits/stdc++.h>
using namespace std; 
using i64 = long long;

void solve() {
    int n; cin >> n;
    string s; cin >> s;
    string x = "aeiou";
    string v = x;
    auto dist = [&](char a, char b) -> int {
        int x = v.find(a), y = v.find(b);
        int res = (y >= x ? y - x : 5 + y - x);
        // cout << a << " " << b << '\n';
        // cout << x << " " << y << '\n';
        // cout << "res " << res << '\n';
        return res;
    };
    int ans = 1e9;
    do {
        // cout << x << '\n';
        vector<int> dp(5);
        for (int i = 0; i < n; i++) {
            for (int j = 4; j > 0; j--) {
                dp[j] = min(dp[j] + dist(s[i], x[j]), (j - 1 >= 0 ? dp[j - 1] : 0) + dist(s[i], x[j]));
            }
            dp[0] += dist(s[i], x[0]);
            // for (auto& a : dp) cout << a << " "; cout << '\n';
        }
        ans = min(ans, *min_element(dp.begin(), dp.end()));
        // cout << "ans " << ans << '\n';
    } while (next_permutation(x.begin(), x.end()));
    cout << ans << '\n';
} 

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int tt = 1;
    cin >> tt;
    for(int t = 1; t <= tt; t++) {
        solve();
    }
}

Information

Submit By
Type
Submission
Problem
P1140 Vowel arrangement
Contest
LU IUJPC : Sylhet Division 2024 Replay Contest
Language
C++17 (G++ 13.2.0)
Submit At
2024-12-10 12:26:16
Judged At
2024-12-10 12:26:16
Judged By
Score
100
Total Time
1203ms
Peak Memory
796.0 KiB