news 2026/5/23 14:51:11

(200分)- 寻找符合要求的最长子串(Java JS Python)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(200分)- 寻找符合要求的最长子串(Java JS Python)

(200分)- 寻找符合要求的最长子串(Java & JS & Python)

题目描述

给定一个字符串s,找出这样一个子串:

  1. 该子串中任意一个字符最多出现2次
  2. 该子串不包含指定某个字符

请你找出满足该条件的最长子串的长度

输入描述

第一行为:要求不包含的指定字符,为单个字符,取值范围[0-9a-zA-Z]

第二行为:字符串s,每个字符范围[0-9a-zA-Z],长度范围[1, 10000]

输出描述

一个整数,满足条件的最长子串的长度;

如果不存在满足条件的子串,则返回0

用例
输入D
ABC132
输出6
说明
输入D
ABACA123D
输出7
说明
题目解析

简单的滑窗应用。

我们以用例2画图解释:

由于本题描述中说:字符串s,每个字符范围[0-9a-zA-Z],以及屏蔽字符取值范围[0-9a-zA-Z],因此我们统计滑窗内部字符数量时,可以使用长度为128的数组来作为容器,因为要统计的字符的ASCII码必然在0~128范围中。

JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); const lines = []; rl.on("line", (line) => { lines.push(line); if (lines.length === 2) { console.log(getResult(lines[1], lines[0])); lines.length = 0; } }); /** * @param {*} s 字符串s * @param {*} ex 要求不包含的指定字符 * @returns 满足条件的最长子串的长度 */ function getResult(s, ex) { ex = ex.charCodeAt(); const count = new Array(128).fill(0); let l = 0; // 滑窗左边界 let r = 0; // 滑窗右边界 let ans = 0; // 记录满足条件的最长子串的长度 // 滑窗右边界不越界的话,可以继续右移 while (r < s.length) { // r指针指向的字符是滑窗新增的字符 const add_c = s[r].charCodeAt(); if (ex == add_c) { // 如果新增字符是屏蔽字符,那么滑窗不能包含此字符,为了让滑窗不能包含此字符,只能让滑窗的左边界l移动到此字符的右边一个位置 ans = Math.max(ans, r - l); // 但是在具体移动之前,需要将上一个状态的滑窗长度,和统计的最大长度进行比较,保留最大的 l = ++r; // 滑窗左边界l要移动到屏蔽字符的右边,即r+1位置,而滑窗的右边界r又不能落后于左边界l,因此相当于同时移动 count.fill(0); // 此时滑窗为空,因此清空统计的字符的数量 } else { // 如果新增字符不是屏蔽字符,那么就纳入滑窗 count[add_c]++; // 如果此时新增字符的数量超过了2,那么我们应该让滑窗的左边界l右移,直到该新增字符的数量等于2时停止 if (count[add_c] > 2) { ans = Math.max(ans, r - l); // 但是在具体移动之前,我们需要将上一个状态的滑窗长度,和统计的最大长度进行比较,保留最大的 } while (count[add_c] > 2) { const remove_c = s[l].charCodeAt(); count[remove_c]--; l++; } r++; } } return Math.max(ans, r - l); // 对最后一次滑窗位置进行记录 }
Java算法源码
import java.util.Arrays; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String exclude = sc.next(); String s = sc.next(); System.out.println(getResult(s, exclude.charAt(0))); } public static int getResult(String s, char ex) { // 记录滑窗内部每个字符出现的次数 int[] count = new int[128]; // 滑窗左边界,右边界 int l = 0, r = 0; // 记录满足条件的最长子串的长度 int ans = 0; // 滑窗右边界不越界的话,可以继续右移 while (r < s.length()) { // r指针指向的字符是滑窗新增的字符 char add_c = s.charAt(r); if (ex == add_c) { // 如果新增字符是屏蔽字符,那么滑窗不能包含此字符,为了让滑窗不能包含此字符,只能让滑窗的左边界l移动到此字符的右边一个位置 ans = Math.max(ans, r - l); // 但是在具体移动之前,需要将上一个状态的滑窗长度,和统计的最大长度进行比较,保留最大的 l = ++r; // 滑窗左边界l要移动到屏蔽字符的右边,即r+1位置,而滑窗的右边界r又不能落后于左边界l,因此相当于同时移动 Arrays.fill(count, 0); // 此时滑窗为空,因此清空统计的字符的数量 } else { // 如果新增字符不是屏蔽字符,那么就纳入滑窗 count[add_c]++; // 如果此时新增字符的数量超过了2,那么我们应该让滑窗的左边界l右移,直到该新增字符的数量等于2时停止 if (count[add_c] > 2) { ans = Math.max(ans, r - l); // 但是在具体移动之前,我们需要将上一个状态的滑窗长度,和统计的最大长度进行比较,保留最大的 } while (count[add_c] > 2) { char remove_c = s.charAt(l); count[remove_c]--; l++; } r++; } } return Math.max(ans, r - l); // 对最后一次滑窗位置进行记录 } }
Python算法源码
# 输入获取 ex = ord(input()) # 要求不包含的指定字符 s = input() # 字符串s # 算法入口 def getResult(): # 记录滑窗内部每个字符出现的次数 count = [0]*128 l = 0 # 滑窗左边界 r = 0 # 滑窗右边界 ans = 0 # 记录满足条件的最长子串的长度 # 滑窗右边界不越界的话,可以继续右移 while r < len(s): # r指针指向的字符是滑窗新增的字符 add_c = ord(s[r]) if ex == add_c: # 如果新增字符是屏蔽字符,那么滑窗不能包含此字符,为了让滑窗不能包含此字符,只能让滑窗的左边界l移动到此字符的右边一个位置 ans = max(ans, r - l) # 但是在具体移动之前,需要将上一个状态的滑窗长度,和统计的最大长度进行比较,保留最大的 r += 1 # 滑窗左边界l要移动到屏蔽字符的右边,即r+1位置,而滑窗的右边界r又不能落后于左边界l,因此相当于同时移动 l = r count = [0]*128 # 时滑窗为空,因此清空统计的字符的数量 else: # 如果新增字符c是目标子串可以包含的字符 count[add_c] += 1 # 那么就纳入滑窗 if count[add_c] > 2: # 如果此时新增字符的数量超过了2,那么我们应该让滑窗的左边界l右移,直到该新增字符的数量等于2时停止 ans = max(ans, r - l) # 但是在具体移动之前,我们需要将上一个状态的滑窗长度,和统计的最大长度进行比较,保留最大的 while count[add_c] > 2: remove_c = ord(s[l]) count[remove_c] -= 1 l += 1 r += 1 # 对最后一次滑窗位置进行记录 return max(ans, r - l) # 算法调用 print(getResult())
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 3:25:46

用 Flutter 做一个“会呼吸”的情绪灯 —— 不写 App,只玩光与动效

用 Flutter 做一个“会呼吸”的情绪灯 —— 不写 App&#xff0c;只玩光与动效** 当人们谈起 Flutter&#xff0c;总说&#xff1a;“跨平台”、“高性能 UI”、“Material Design”。 但今天&#xff0c;我们不做一个 App&#xff0c;不写列表、不连 API、不搞登录页。 我们…

作者头像 李华
网站建设 2026/5/22 20:43:12

某海外 _signature签名分析

1. 目标 aHR0cHM6Ly93d3cudGlrdG9rLmNvbS9hcGkvc2hvcC91cy9ob21lcGFnZV9kZXNrdG9wL3NlYXJjaF93b3JkX3N1Z2dlc3Rpb24/bXNUb2tlbj1mWEItOHRoRU9hNllIblkyellKM1lLaDlBMUtGeks3NnpXWjk2bnRwMUlldjNjTDFBdmNQRllpTmtLVllXUThLNVhYUkdJRFd4VjM2ekxWWEtPNFNLLWNGUFpjLU44cGhab1pWMW1k…

作者头像 李华
网站建设 2026/5/21 10:34:06

【毕业设计】基于springboot+微信小程序的集换社卡牌的交易系统小程序(源码+文档+远程调试,全bao定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/21 11:47:23

计算机小程序毕设实战-基于SpringBoot的交通违法有奖曝光平台设计与基于springboot+微信小程序的的交通违法有奖曝光平台【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/23 4:30:46

HTML行内块标签——img、表单、音视频标签

目录 概念&#xff1a;特殊的标签&#xff0c;有自己独有的功能 img标签&#xff1a; 表单&#xff1a; 1、input表单项 2、下拉框表单项:select 3、内容框&#xff1a;textarea 4、按钮 button 5、去除表单默认样式 ​编辑 音视频标签 概念&#xff1a;特殊的标签&a…

作者头像 李华
网站建设 2026/5/23 10:03:45

微信ipad协议,wechatapi,个人号二次开发

微信生态安全挑战与防护策略微信作为拥有13亿月活用户的平台&#xff0c;其安全体系具有高度复杂性。未经优化的自动化工具面临极高封号风险&#xff1a;第一周35%、一个月65%、三个月85%、六个月95%。微信风控系统技术原理设备层防护 微信采集50设备特征参数&#xff0c;包括硬…

作者头像 李华