1234. 替换子串得到平衡字符串

Problem: 1234. 替换子串得到平衡字符串

文章目录

  • 思路
  • 解题方法
  • 复杂度
  • Code

思路

这是一个滑动窗口问题。我们需要找到一个最小的子串,使得将其替换后,字符串中四种字符 ‘Q’, ‘W’, ‘E’, ‘R’ 的数量相等。我们可以通过滑动窗口的方式,找到一个子串,使得其外部的字符数量满足平衡条件。

解题方法

我们首先统计字符串中四种字符的数量,然后计算出每种字符应有的数量(字符串长度的四分之一)。然后我们使用两个指针 l 和 r,表示当前的窗口范围。我们不断地向右移动 r,直到窗口外的字符数量满足平衡条件。然后我们尝试向右移动 l,看看是否仍然满足平衡条件。如果满足,那么我们就找到了一个更小的满足条件的子串。我们不断重复这个过程,直到找到最小的满足条件的子串。

复杂度

时间复杂度:

O ( n ) O(n) O(n),我们需要遍历整个字符串。

空间复杂度:

O ( 1 ) O(1) O(1),我们只需要常数级别的空间来存储字符的数量。

Code

class Solution {public static int balancedString(String str) {int n = str.length();int[] arr = new int[n];int[] cnts = new int[4];for (int i = 0; i < n; i++) {char c = str.charAt(i);arr[i] = c == 'W' ? 1 : (c == 'E' ? 2 : (c == 'R' ? 3 : 0));cnts[arr[i]]++;}int require = n / 4; // 每种字符串需要的长度int ans = n; // 需要修改的长度for (int l = 0, r = 0; l < n; l++) {while (!ok(cnts, r - l, require) && r < n) {cnts[arr[r++]]--;}if (ok(cnts, r - l, require)) {ans = Math.min(ans, r - l);}cnts[arr[l]]++;}return ans;}private static boolean ok(int[] cnts, int len, int require) {for(int i = 0; i < 4; i++) {if(cnts[i] > require) {return false;}len -= require - cnts[i];}return len == 0;}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/722894.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML实体字符列表,必看

HTML、CSS、JS三大部分都起什么作用&#xff1f; HTML内容层&#xff0c;它的作用是表示一个HTML标签在页面里是个什么角色&#xff1b;CSS样式层&#xff0c;它的作用是表示一块内容以什么样的样式&#xff08;字体、大小、颜色、宽高等&#xff09;显示&#xff1b;JS行为层…

基于QGIS的研究区域遥感影像裁切下载方法-以岳麓区为例

目录 前言 一、数据说明 1、遥感影像 2、矢量范围 二、按矢量范围导出 1、第一步、导出影像 2、第二步、设置输出格式 3、设置裁切范围 4、设置分辨率 三、按矢量范围掩膜 1、第一步、打开裁剪工具 2、第二步、参数设置 ​编辑 3、执行掩膜 四、webgis支持 1、生成运行…

计算机基础(面试重点)

文章目录 1. 计算机网络1.1 TCP/IP四层模型与OSI七层模型1.2 HTTP协议原理1.2.1 消息结构1.2.2 HTTP常见请求方法1.2.3 常见状态码 1.3 HTTPS协议原理1.4 TCP与UDP1.4.1 TCP三次握手1.4.2 TCP四次挥手1.4.3 常见热点问题1.4.4 浏览器输入URL并回车的过程以及相关协议&#xff1…

mac上更改vscode快捷键

以移动当前行代码为例 mac上的vscode&#xff0c;默认移动当前行代码的快捷键是⌥↑即option↑按键 现在我想改成command↑ 步骤如下 1.打开vscode-code-首选项-键盘快捷键 2.打开快捷键列表 3.输入move line&#xff0c;找到要改动的这个快捷键 当前行-右键-更改键绑定&…

【Redis】实际应用 - 监控工具

文章目录 1. Redis官方监控系统1.1 RedisInsight 2. 第三方Redis监控工具2.1 redis-stat2.2 KeyDB Web2.3 Netdata 3. 使用监控工具的好处4. 结语 在使用Redis作为数据存储引擎时&#xff0c;对其性能进行实时监控是确保系统稳定性和高性能的重要一环。本篇博客将介绍一些常用的…

pyg-创建消息传递网络

创建消息传递网络 — pytorch_geometric 文档 (pytorch-geometric.readthedocs.io) https://arxiv.org/abs/1801.07829 import torch from torch.nn import Sequential as Seq, Linear, ReLU from torch_geometric.nn import MessagePassing class EdgeConv(MessagePassing): …

数组转成set的底层实现

数组转成set的底层实现 要将Java数组转换为Set集合&#xff0c;可以使用Java集合框架中的HashSet或TreeSet。HashSet是基于哈希表的实现&#xff0c;不保证元素的顺序&#xff0c;而TreeSet是基于红黑树的实现&#xff0c;可以将元素按照一定顺序进行排序。 示例 下面是将Java数…

C语言 字符串的移动(滚动)数组的移动

/*字符串滚动 例:输入abcdef 像左移动3位 输出defabc*/ #include <stdio.h> #include <string.h> int main() {int i,t,n;char a[100],b[100];printf("请输入一串字符串&#xff1a;\n");gets(a);printf("向左还是向右移动&#xff08;1.左 2.右&…

鸿蒙 进程模型-公共事件

前提&#xff1a;基于官网3.1/4.0文档。参考官网文档 基于Android开发体系来进行比较和思考。&#xff08;或有偏颇&#xff0c;自行斟酌&#xff09; 一、 概念 应用中&#xff08;同一包名&#xff09;的所有UIAbility运行在同一个独立进程中。WebView拥有独立的渲染进程。 应…

微信小程序云开发教程——墨刀原型工具入门(页面交互+交互案例教程)

引言 作为一个小白&#xff0c;小北要怎么在短时间内快速学会微信小程序原型设计&#xff1f; “时间紧&#xff0c;任务重”&#xff0c;这意味着学习时必须把握微信小程序原型设计中的重点、难点&#xff0c;而非面面俱到。 要在短时间内理解、掌握一个工具的使用&#xf…

excel统计分析——析因设计

参考资料&#xff1a;生物统计学 析因设计&#xff08;factorial design&#xff09;是同时研究多因素主效应和互作的有效试验设计方法。将所研究的因素按全部因素的所有水平的一切组合逐次进行试验&#xff0c;称为析因设计&#xff0c;也称为全因子试验设计。 1、设计方法 析…

web前端之uniApp实现选择时间功能

MENU 1、孙子组件1.1、html部分1.2、JavaScript部分1.3、css部分 2、子组件2.1、html部分2.2、JavaScript部分2.3、css部分 3、父组件3.1、html部分3.2、JavaScript部分 4、效果图 1、孙子组件 1.1、html部分 <template><view><checkbox-group change"ch…

蓝桥杯-大小写转换

转换方法 toLowerCase() String类的toLowerCase()方法可以将字符串中的所有字符全部转换成小写&#xff0c;而非字母的字符不受影响&#xff0c;语法格式如下&#xff1a; 字符串名.toLowerCase() //将字符串中的字母全部转成小写&#xff0c;非字母不受影响。 package chap…

nginx 基于IP的多虚拟主机配置

nginx 基于IP的多虚拟主机配置 1.基于IP的多虚拟主机配置 1.1 网络配置 linux操作系统支持IP别名的添加。 nginx 服务器提供的每台虚拟主机对应配置一个不同的IP&#xff0c;因此需要将网卡设置为同时能够监听多个IP地址。 先查看当前的网络配置&#xff1a;ifconfig 再为…

python 绘制三维图

参考&#xff1b;Create 3D histogram of 2D data — Matplotlib 3.8.3 documentation

Elasticsearch:使用 Streamlit、语义搜索和命名实体提取开发 Elastic Search 应用程序

作者&#xff1a;Camille Corti-Georgiou 介绍 一切都是一个搜索问题。 我在 Elastic 工作的第一周就听到有人说过这句话&#xff0c;从那时起&#xff0c;这句话就永久地印在了我的脑海中。 这篇博客的目的并不是我出色的同事对我所做的相关陈述进行分析&#xff0c;但我首先…

PHP服务性能优化总结

前言 问题都是逐步暴露的&#xff0c;没有显现出来的问题不代表不存在&#xff0c;只是有更低级的问题先出现了而已。特别是对于 service 来说&#xff0c;问题出现之后&#xff0c;必须要找到根因&#xff0c;找到根因之后&#xff0c;解决方案可以分布实施&#xff0c;否则所…

【Numpy】给数组增加一个维度

【Numpy】给数组增加一个维度 &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程&#x1f448; 希望得到您的订阅和支持~ &#x1f4a1; 创…

怎么培养孩子的学习习惯?

问&#xff1a;在亲子阅读中&#xff0c;应该用哪些方法引导孩子自己主动阅读呢&#xff1f; 有很多家长会问如何培养孩子主动阅读的兴趣&#xff1f; 我想给你四个词来分享&#xff0c;分别是环境、选择的权利、适龄&#xff0c;还有增强回路。第一个环境&#xff0c;就是把…

Java @Async 实现异步功能

1.问题描述 在做导入导出功能时&#xff0c;如果数据量比较多&#xff0c;完成操作的时间就会变长&#xff0c;导致页面的接口报502超时异常 2.原因分析 没有做异步处理&#xff0c;同步处理会导致页面要一直等待接口响应&#xff0c;时间一长就会报502 3.解决方案 改为异步导…