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

时间:2023-01-17 12:11:13

题目链接: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();
}

Codeforces Round #656 (Div. 3) D. a-Good String的更多相关文章

  1. Codeforces Round &num;184 &lpar;Div&period; 2&rpar; E&period; Playing with String(博弈)

    题目大意 两个人轮流在一个字符串上删掉一个字符,没有字符可删的人输掉游戏 删字符的规则如下: 1. 每次从一个字符串中选取一个字符,它是一个长度至少为 3 的奇回文串的中心 2. 删掉该字符,同时,他 ...

  2. Codeforces Round &num;297 &lpar;Div&period; 2&rpar;B&period; Pasha and String 前缀和

    Codeforces Round #297 (Div. 2)B. Pasha and String Time Limit: 2 Sec  Memory Limit: 256 MBSubmit: xxx ...

  3. 字符串处理 Codeforces Round &num;297 &lpar;Div&period; 2&rpar; B&period; Pasha and String

    题目传送门 /* 题意:给出m个位置,每次把[p,len-p+1]内的字符子串反转,输出最后的结果 字符串处理:朴素的方法超时,想到结果要么是反转要么没有反转,所以记录 每个转换的次数,把每次要反转的 ...

  4. Codeforces Round &num;877 &lpar;Div&period; 2&rpar; B&period; - Nikita and string

    题目链接:http://codeforces.com/contest/877/problem/B Nikita and string time limit per test2 seconds memo ...

  5. Codeforces Round &num;656 &lpar;Div&period; 3&rpar; C&period; Make It Good

    题目链接:https://codeforces.com/contest/1385/problem/C 题意 去除一个数组的最短前缀使得余下的数组每次从首或尾部取元素可以排为非减序. 题解一 当两个大数 ...

  6. Codeforces Round &num;656 &lpar;Div&period; 3&rpar; B&period; Restore the Permutation by Merger

    题目链接:https://codeforces.com/contest/1385/problem/B 题意 有两个大小为 $n$ 的相同的排列,每次从二者或二者之一的首部取元素排入新的数组,给出这个大 ...

  7. Codeforces Round &num;656 &lpar;Div&period; 3&rpar; A&period; Three Pairwise Maximums

    题目链接:https://codeforces.com/contest/1385/problem/A 题意 给出三个正整数 $x,y,z$,找出三个正整数 $a,b,c$ 使得 $x = max(a, ...

  8. Codeforces Round &num;656 &lpar;Div&period; 3&rpar; 题解

    A. Three Pairwise Maximums #构造 题目链接 题意 给定三个正整数\(x,y,z\),要求找出正整数\(a,b,c\),满足\(x=max(a,b), y=max(a,c), ...

  9. Codeforces Round &num;656 &lpar;Div&period; 3&rpar; D&period; a-Good String &lpar;DFS&rpar;

    题意:有一个长度为\(n=2^k\)的字符串,对于某个字符\(c\),我们定义他是一个\(c-good\),如果: ​ 1.\(len=1\),并且\(s[1]=c\). ​ 2.\(len>1 ...

随机推荐

  1. git 提交空文件夹

    git不能提交空文件夹 find . -type d -empty -execdir touch {}/.gitkeep \; -type -d 搜索文件夹 -empty 只搜索空文件夹 -execd ...

  2. SC&period;UI

    IController using Microsoft.Practices.Prism.Events; using Microsoft.Practices.Prism.Regions; using M ...

  3. Android 5&period;x特性概览四

    上节,我们说了palatte及其特性,这里我们介绍Android 5.x的另一个特性视图与阴影. 在第一节,我们就提到了Material Design 一大特性就是就是扁平化,倘若说 iOS 的扁平化 ...

  4. 解放程序猿宝贵的右手(或者是左手) ——Android自动化测试技巧

    解放双手--Android自动化测试 - eclipse_xu - 博客频道 - CSDN.NET 解放程序猿宝贵的右手(或者是左手) --Android自动化测试技巧

  5. C程序设计语言练习题1-3

    练习1-3 修改温度转换程序,使之能在转换表的顶部打印一个标题. 代码如下: #include <stdio.h> // 包含标准库的信息. int main() // 定义名为main的 ...

  6. 删除style的样式JQuery

      有些页面样式不规范,没有写在一个class里,例如:<div id="show" style="width:100px; padding-top:10px; f ...

  7. python命令调用函数os&period;popen

    参考自xerosploit 描述:利用os.popen()函数调用系统命令nmap进行扫描,并用grep命令对扫描结果关键内容进行提取 代码 #!/usr/bin/env pthon #--*--co ...

  8. linux top指令信息表示

    top指令: PID ====  进程号 USER ==== 进程所有者 PR ====  进程优先级 NI ====  进程优先级别数值 VIRT ==== 进程占用的虚拟内存 RES ====   ...

  9. Linux 小知识翻译 - 「服务器」

    这次聊聊 「服务器」 这个词. 可能会觉得为什么「突然问这个?」.接下来请先考虑一下下面的题目. A) 「Web服务器是指提供网页数据的软件」 B) 「Web服务器是指运行上述软件的硬件」 那么,究竟 ...

  10. vue里面axios使用post

    let params = new URLSearchParams(); params.append('action', "login"); params.append('user' ...