国外医院网站设计网站开发树形图

张小明 2026/1/12 18:27:59
国外医院网站设计,网站开发树形图,上海远程教育网站设计与开发公司,wordpress 安卓主题下载失败(200分)- 寻找符合要求的最长子串#xff08;Java JS Python#xff09;题目描述给定一个字符串s#xff0c;找出这样一个子串#xff1a;该子串中任意一个字符最多出现2次该子串不包含指定某个字符请你找出满足该条件的最长子串的长度输入描述第一行为#x…(200分)- 寻找符合要求的最长子串Java JS Python题目描述给定一个字符串s找出这样一个子串该子串中任意一个字符最多出现2次该子串不包含指定某个字符请你找出满足该条件的最长子串的长度输入描述第一行为要求不包含的指定字符为单个字符取值范围[0-9a-zA-Z]第二行为字符串s每个字符范围[0-9a-zA-Z]长度范围[1, 10000]输出描述一个整数满足条件的最长子串的长度如果不存在满足条件的子串则返回0用例输入DABC132输出6说明无输入DABACA123D输出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要移动到屏蔽字符的右边即r1位置而滑窗的右边界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要移动到屏蔽字符的右边即r1位置而滑窗的右边界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要移动到屏蔽字符的右边即r1位置而滑窗的右边界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进行投诉反馈,一经查实,立即删除!

seo网站模版免费的查企业的网站

Whisky魔法手册:5大技巧让Windows程序在macOS上飞起来 【免费下载链接】Whisky A modern Wine wrapper for macOS built with SwiftUI 项目地址: https://gitcode.com/gh_mirrors/wh/Whisky 还在为macOS无法运行Windows专属软件而烦恼吗?Whisky作…

张小明 2026/1/11 7:41:03 网站建设

做网站需要多少费用百度网站关键词和网址

第一章:医疗系统数据安全概述在数字化转型加速的背景下,医疗系统正日益依赖电子健康记录(EHR)、远程诊疗平台和云端数据存储。这些技术提升了医疗服务效率,但也使患者敏感信息面临前所未有的安全威胁。医疗数据包含个人…

张小明 2026/1/10 10:18:12 网站建设

邯郸网站建设优化排名建网站外包需要多少钱

Sonic数字人入门:从零开始掌握口型同步核心技术 在短视频与虚拟内容爆发的今天,你是否曾想过,仅凭一张照片和一段录音,就能让一个“数字人”活灵活现地为你播报新闻、讲课或直播带货?这不再是科幻电影的情节——Sonic …

张小明 2026/1/10 12:32:59 网站建设

自己电脑做网站模板企业的网站做一个要多少

Mathtype学术写作助手升级:接入VoxCPM-1.5-TTS-WEB-UI语音朗读 在科研写作日益数字化的今天,一个困扰学者多年的问题始终存在:我们能轻松写下复杂的数学公式,却无法“听见”它们。对于视障研究者、非母语写作者,或是长…

张小明 2026/1/11 0:58:02 网站建设

怎么盗用网站网页设计图片大小

Wechaty智能对话系统v1.20.2:3大核心模块让RPA开发效率提升300% 【免费下载链接】wechaty 项目地址: https://gitcode.com/gh_mirrors/wec/wechaty 还在为聊天机器人开发中的复杂配置、消息处理繁琐、群聊管理低效而困扰吗?Wechaty v1.20.2版本带…

张小明 2026/1/10 23:50:47 网站建设

如何判断网站是竞价站学校网页制作视频教程

在移动端开发中,交互组件的性能直接影响用户体验。本文将通过Mobile Select组件库,深入探讨移动端组件开发的核心技术和最佳实践。 【免费下载链接】mobile-select mobile-select: 是一个多功能的移动端滚动选择器,支持单选到多选&#xff0c…

张小明 2026/1/12 7:52:23 网站建设