Codeforces Round #656 (Div. 3) D. a-Good String

题目链接:https://codeforces.com/contest/1385/problem/D

题意

一个小写字母串称为 $c-good\ string$,如果至少满足以下条件之一:

  • 字符串长度为 $1$,包含字母 $c$
  • 字符串前一半都为字母 $c$,后一半为 $(c+1)-good\ string$ 
  • 字符串后一半都为字母 $c$,前一半为 $(c+1)-good\ string$ 

计算将一个长为 $n = 2^k$ 的小写字母串变为 $a-good\ string$ 至少需要替换多少个字符。

题解

递归枚举所有情况即可。

代码

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

int n;
string s;

int dfs(int l, int r, char c) {
    if (l + 1 == r) return s[l] != c;
    int l1 = l, r1 = l + (r - l) / 2;
    int cnt1 = r1 - l1 - count(s.begin() + l1, s.begin() + r1, c);
    int l2 = l + (r - l) / 2, r2 = r;
    int cnt2 = r2 - l2 - count(s.begin() + l2, s.begin() + r2, c);
    return min(cnt1 + dfs(l2, r2, c + 1), cnt2 + dfs(l1, r1, c + 1));
}

void solve() {
    cin >> n >> s;
    cout << dfs(0, n, 'a') << "\n";
}

int main() {
    int t; cin >> t;
    while (t--) solve();
}

 

posted @ 2020-07-18 01:06  Kanoon  阅读(187)  评论(0编辑  收藏  举报