news 2026/2/17 8:08:07

每日算法练习Day03

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
每日算法练习Day03

题目来源

U535982 C-小梦的AB交换 - 洛谷

题目描述

小梦有一个长度为 2∗n 的 AB 串 s,即 s 中只包含 "A" 和 "B" 两种字符,且其中恰好有 n 个 "A" 和 n 个 "B"。

他可以对 s 执行以下操作:

∙ 选择 i,j (1≤i,j≤2⋅n,i=j),并交换 si​ 和 sj​。

他想知道,需要至少多少次操作,才能使得 s 满足相邻的字符不相同,请你帮他算一算吧。

输入格式

本题有多组测试数据。

输入的第一行包含一个正整数 T,表示数据组数。

接下来包含 T 组数据,每组数据的格式如下:

第一行一个正整数 n,表示 s 长度的一半。

第二行一个长度为 2∗n 的字符串 s,保证只由 "A", "B" 两种字符构成。

输出格式

对于每组测试数据:

在单独的一行输出一个整数,表示最少进行的操作次数。

输入输出样例

输入 #1复制

2 3 AAABBB 3 ABAABB

输出 #1复制

1 1

说明/提示

【样例 1 解释】

交换 s2​=A 和 s5​=B,得到 s= "ABABAB",满足题意,一次交换即可。

【数据范围】

令 N 表示 T 组数据中 n 的总和。

对于 50% 的数据有:T=1,1≤N≤3。

对于所有的测试数据有: 1≤T≤100,1≤N≤106。

题解

import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int T = sc.nextInt(); // 读取测试数据组数 while (T-- > 0) { int n = sc.nextInt(); // 每组数据的n String s = sc.next(); // 每组数据的字符串s // 构建两种合法的交替字符串: // 形式1:B开头,交替排列(B A B A...) StringBuilder pattern1 = new StringBuilder(); // 形式2:A开头,交替排列(A B A B...) StringBuilder pattern2 = new StringBuilder(); for (int i = 0; i < 2 * n; i++) { if (i % 2 == 0) { // 偶数位(从0开始) pattern1.append('B'); pattern2.append('A'); } else { // 奇数位 pattern1.append('A'); pattern2.append('B'); } } // 计算原字符串与两种形式的差异数,交换次数=差异数/2 int cost1 = calcDiff(s, pattern1.toString()); int cost2 = calcDiff(s, pattern2.toString()); // 输出最小交换次数 System.out.println(Math.min(cost1, cost2)); } sc.close(); } // 计算原字符串与目标模式的差异数,返回交换次数(差异数/2) private static int calcDiff(String s, String pattern) { int diff = 0; for (int i = 0; i < s.length(); i++) { if (s.charAt(i) != pattern.charAt(i)) { diff++; } } return diff / 2; }

1. 先获取数据组数

2.然后我们可以用循环来获取数据

3.建立两种模式来实现这个字母不同的结果,最后再比较这个操作过后的字符串和原来的字符串的区别即可

注释:

s.charAt(i)是获取数组中对应的字母

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/31 13:20:30

**AI漫剧生成工具2025推荐,解锁高效创作与视觉叙事新体

AI漫剧生成工具2025推荐&#xff0c;解锁高效创作与视觉叙事新体验在内容创作领域&#xff0c;一场由AI驱动的视觉叙事革命正在加速。据《2025中国数字内容产业白皮书》显示&#xff0c;2025年AI生成视频内容的市场需求同比增长超过300%&#xff0c;其中AI漫剧因其独特的视觉风…

作者头像 李华
网站建设 2026/2/5 15:59:24

Linux下串口波特率配置命令操作指南

以下是对您提供的博文内容进行 深度润色与结构优化后的技术文章 。整体遵循“去AI化、强工程感、重逻辑流、轻模板化”的原则,彻底摒弃引言/总结等程式化段落,以一位嵌入式Linux一线工程师的口吻娓娓道来——既有踩坑后的顿悟,也有调试时的真实节奏;既讲清楚“怎么做”,…

作者头像 李华
网站建设 2026/2/14 9:48:59

Qwen3-4B惊艳效果展示:多语言代码注释自动生成(含中文)

Qwen3-4B惊艳效果展示&#xff1a;多语言代码注释自动生成&#xff08;含中文&#xff09; 1. 开场&#xff1a;一段代码&#xff0c;三秒加注释&#xff0c;中英法德日全搞定 你有没有过这样的时刻&#xff1a;翻出半年前写的Python脚本&#xff0c;第一行就卡住——这函数到…

作者头像 李华
网站建设 2026/2/14 19:10:50

YOLOv9训练太难?这个镜像让你省心又高效

YOLOv9训练太难&#xff1f;这个镜像让你省心又高效 你是不是也经历过这样的深夜&#xff1a;显卡风扇狂转&#xff0c;终端里反复报错CUDA out of memory&#xff1b;改了十遍data.yaml路径&#xff0c;train_dual.py还是提示No images found&#xff1b;好不容易跑通一轮训练…

作者头像 李华
网站建设 2026/2/1 6:53:11

精准破局公众号排名:算法加权+用户价值双向驱动策略

在微信搜一搜生态中&#xff0c;公众号排名直接决定自然流量天花板&#xff0c;数据显示搜索结果前3位账号占据超70%点击量&#xff0c;排名10名后曝光量不足5%。多数运营者陷入“关键词堆砌却排名低迷”的困境&#xff0c;核心是忽视了算法“用户价值优先”的底层逻辑。本文从…

作者头像 李华
网站建设 2026/2/1 1:38:58

VibeVoice一键部署脚本解析:start_vibevoice.sh自动化原理揭秘

VibeVoice一键部署脚本解析&#xff1a;start_vibevoice.sh自动化原理揭秘 1. 为什么需要一个启动脚本&#xff1f; 你有没有试过部署一个AI项目&#xff0c;光是看文档就花了半小时&#xff0c;复制粘贴命令时还漏掉了一个环境变量&#xff1f;最后卡在“ModuleNotFoundErro…

作者头像 李华