news 2026/6/10 19:55:57

(新卷,100分)- 完美走位(Java JS Python)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,100分)- 完美走位(Java JS Python)

(新卷,100分)- 完美走位(Java & JS & Python)

题目描述

在第一人称射击游戏中,玩家通过键盘的A、S、D、W四个按键控制游戏人物分别向左、向后、向右、向前进行移动,从而完成走位。

假设玩家每按动一次键盘,游戏任务会向某个方向移动一步,如果玩家在操作一定次数的键盘并且各个方向的步数相同时,此时游戏任务必定会回到原点,则称此次走位为完美走位。

现给定玩家的走位(例如:ASDA),请通过更换其中一段连续走位的方式使得原走位能够变成一个完美走位。其中待更换的连续走位可以是相同长度的任何走位。

请返回待更换的连续走位的最小可能长度。

如果原走位本身是一个完美走位,则返回0。

输入描述

输入为由键盘字母表示的走位s,例如:ASDA

输出描述

输出为待更换的连续走位的最小可能长度。

用例
输入WASDAASD
输出1
说明将第二个A替换为W,即可得到完美走位
输入AAAA
输出3
说明将其中三个连续的A替换为WSD,即可得到完美走位
题目解析

题目要求,保持W,A,S,D字母个数平衡,即相等,如果不相等,可以从字符串中选取一段连续子串替换,来让字符串平衡。

比如:WWWWAAAASSSS

字符串长度12,W,A,S,D平衡的话,则每个字母个数应该是3个,而现在W,A,S各有4个,也就是说各超了1个。

因此我们应该从字符串中,选取一段包含1个W,1个A,1个S的子串,来替换为D。

WWWWAAAASSSS

WWWWAAAASSSS

WWWWAAAASSSS

........

WWWWAAAASSSS

而符合这种要求的子串可能很多,我们需要找出其中最短的,即WAAAAS。

本题其实就是求最小覆盖子串

JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { console.log(getResult(line)); }); function getResult(str) { // 此时count记录统计W,A,S,D字母的数量 const count = { W: 0, A: 0, S: 0, D: 0, }; for (let c of str) count[c]++; // 平衡状态时,W,A,S,D应该都是avg数量 const avg = str.length / 4; let total = 0; // total用于记录多余字母个数 let flag = true; // flag表示当前是否为平衡状态,默认是 for (let c in count) { if (count[c] > avg) { flag = false; // 如果有一个字母数量超标,则平衡打破 count[c] -= avg; // 此时count记录每个字母超过avg的数量 total += count[c]; } else { delete count[c]; } } if (flag) return 0; // 如果平衡,则输出0 let i = 0; let j = 0; let minLen = str.length + 1; while (j < str.length) { const jc = str[j]; if (count[jc]-- > 0) { total--; } while (total === 0) { minLen = Math.min(minLen, j - i + 1); const ic = str[i]; if (count[ic]++ >= 0) { total++; } i++; } j++; } return minLen; }
Java算法源码
import java.util.HashMap; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println(getResult(sc.next())); } public static int getResult(String str) { // count用于记录W,A,S,D字母的数量 HashMap<Character, Integer> count = new HashMap<>(); for (int i = 0; i < str.length(); i++) { Character c = str.charAt(i); count.put(c, count.getOrDefault(c, 0) + 1); } // 平衡状态时,W,A,S,D应该都是avg数量 int avg = str.length() / 4; // total用于记录多余字母个数 int total = 0; // flag表示当前是否为平衡状态,默认是 boolean flag = true; for (Character c : count.keySet()) { if (count.get(c) > avg) { // 如果有一个字母数量超标,则平衡打破 flag = false; // 此时count记录每个字母超过avg的数量 count.put(c, count.get(c) - avg); total += count.get(c); } else { count.put(c, 0); // 此时count统计的其实是多余字母,如果没有超过avg,则表示没有多余字母 } } // 如果平衡,则输出0 if (flag) return 0; int i = 0; int j = 0; int minLen = str.length() + 1; while (j < str.length()) { Character jc = str.charAt(j); if (count.get(jc) > 0) { total--; } count.put(jc, count.get(jc) - 1); while (total == 0) { minLen = Math.min(minLen, j - i + 1); Character ic = str.charAt(i); if (count.get(ic) >= 0) { total++; } count.put(ic, count.get(ic) + 1); i++; } j++; } return minLen; } }
Python算法源码
# 输入获取 s = input() # 算法入口 def getResult(s): # 此时count记录统计W,A,S,D字母的数量 count = { "W": 0, "A": 0, "S": 0, "D": 0 } for c in s: count[c] += 1 avg = len(s) / 4 # 平衡状态时,W,A,S,D应该都是avg数量 total = 0 # total用于记录多余字母个数 flag = True # flag表示当前是否为平衡状态,默认是 for c in count.keys(): if count[c] > avg: flag = False # 如果有一个字母数量超标,则平衡打破 count[c] -= avg # 此时count记录每个字母超过avg的数量 total += count[c] else: count[c] = 0 if flag: return 0 # 如果平衡,则输出0 i = 0 j = 0 minLen = len(s) - 1 while j < len(s): jc = s[j] if count[jc] > 0: total -= 1 count[jc] -= 1 while total == 0: minLen = min(minLen, j - i + 1) ic = s[i] if count[ic] >= 0: total += 1 count[ic] += 1 i += 1 j += 1 return minLen print(getResult(s))
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 8:11:25

MATLAB R2025b中消失的Specialized Power Systems库

MATLAB R2025b中消失的Specialized Power Systems库 CSDN为什么要把我的部分文章设置为VIP可读&#xff1f; CSDN为什么要把我的部分文章设置为VIP可读&#xff1f; CSDN为什么要把我的部分文章设置为VIP可读&#xff1f; Specialized Power Systems库介绍 库位置: Librar…

作者头像 李华
网站建设 2026/6/10 8:16:48

FastAPI 基本路由

FastAPI 基本路由 引言 FastAPI 是一个现代、快速(高性能)的 Web 框架,用于构建 API,由 Python 3.6+ 支持。它具有异步功能,并且可以与 Starlette 和 Pydantic 一起使用。本文将深入探讨 FastAPI 的基本路由,包括如何创建、配置和使用路由。 FastAPI 简介 FastAPI 是…

作者头像 李华
网站建设 2026/6/10 8:14:59

MATLAB实现PCA(主成分分析)、OPLS-DA(正交偏最小二乘判别分析)与CRITIC-TOPSIS(基于CRITIC权重的优劣解距离法) 三种方法结合使用多指标综合评价

1. PCA&#xff08;无监督模式识别&#xff09; 目的&#xff1a;初步探索样本间的整体化学差异与分布趋势。 应用步骤&#xff1a; 将银柴胡样本的化学数据&#xff08;如色谱峰面积、成分含量等&#xff09;构建数据矩阵。进行数据标准化&#xff08;如UV scaling或Pareto sc…

作者头像 李华
网站建设 2026/6/10 9:08:28

POD控制器:集群的“自动化运维管家”

在K8S生态中&#xff0c;Pod作为最小部署单元&#xff0c;其生命周期管理与资源配置直接决定了集群的稳定性、可用性与资源利用率。Pod控制器负责确保Pod始终处于期望运行状态&#xff0c;本文将从核心概念、实践配置到最佳实践&#xff0c;全面拆解Pod控制器的关键知识点&…

作者头像 李华
网站建设 2026/6/10 7:56:24

Exolum加速数字化转型以应对能源变革挑战

在能源转型、监管压力以及需要在全球范围内更高效运营的背景下&#xff0c;数字化转型已成为像Exolum这样的工业和物流公司的战略支柱。这家目前业务遍及11个国家、年营业额超过10亿美元的公司&#xff0c;正面临如何保持竞争力的艰难抉择。公司专注于运输汽油和柴油、储存碳氢…

作者头像 李华