牛客题解 | 橡皮泥斑马

news/2025/3/10 10:15:16/文章来源:https://www.cnblogs.com/wc529065/p/18761981

题目

题目链接

解题思路

这是一道字符串处理题目,主要思路如下:

  1. 特殊情况处理:

    • 长度为1:结果为0
    • 长度为2:如果两字符相同为0,不同为2
  2. 一般情况处理:

    • 从头部开始统计连续黑白相间的长度(headLen)
    • 从尾部开始统计连续黑白相间的长度(tailLen)
    • 统计中间部分的最长黑白相间长度
    • 如果首尾字符不同,可以考虑将头尾相连
  3. 最终结果为以上所有可能长度的最大值


代码

#include <iostream>
#include <string>
using namespace std;int main() {string s;while(cin >> s) {int len = s.length();// 特殊情况处理if(len == 1) {cout << "0" << endl;continue;}if(len == 2) {cout << (s[0] == s[1] ? "0" : "2") << endl;continue;}// 计算头部连续长度int headLen = 1, tailLen = 1;int start = 0, end = len - 1;for(; start < end; start++) {if(s[start] == s[start + 1]) break;headLen++;}// 如果扫描到结尾,说明整个串都是相间的if(start == end) {cout << headLen << endl;continue;}// 计算尾部连续长度for(; end > start; end--) {if(s[end] == s[end - 1]) break;tailLen++;}// 找出最大长度int maxLen = max(headLen, tailLen);int tempLen = 1;// 处理中间部分for(start++, end--; start < end; start++) {if(s[start] == s[start + 1]) {maxLen = max(maxLen, tempLen);tempLen = 1;} else {tempLen++;}}// 如果首尾字符不同,可以考虑连接if(s[0] != s[len - 1]) {maxLen = max(maxLen, headLen + tailLen);}cout << maxLen << endl;}return 0;
}
import java.util.*;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);while(sc.hasNext()) {String s = sc.next();int len = s.length();// 特殊情况处理if(len == 1) {System.out.println(0);continue;}if(len == 2) {System.out.println(s.charAt(0) == s.charAt(1) ? 0 : 2);continue;}// 计算头部连续长度int headLen = 1, tailLen = 1;int start = 0, end = len - 1;for(; start < end; start++) {if(s.charAt(start) == s.charAt(start + 1)) break;headLen++;}// 如果扫描到结尾,说明整个串都是相间的if(start == end) {System.out.println(headLen);continue;}// 计算尾部连续长度for(; end > start; end--) {if(s.charAt(end) == s.charAt(end - 1)) break;tailLen++;}// 找出最大长度int maxLen = Math.max(headLen, tailLen);int tempLen = 1;// 处理中间部分for(start++, end--; start < end; start++) {if(s.charAt(start) == s.charAt(start + 1)) {maxLen = Math.max(maxLen, tempLen);tempLen = 1;} else {tempLen++;}}// 如果首尾字符不同,可以考虑连接if(s.charAt(0) != s.charAt(len - 1)) {maxLen = Math.max(maxLen, headLen + tailLen);}System.out.println(maxLen);}}
}
while True:try:s = input()length = len(s)# 特殊情况处理if length == 1:print(0)continueif length == 2:print(0 if s[0] == s[1] else 2)continue# 计算头部连续长度head_len = 1tail_len = 1start = 0end = length - 1while start < end:if s[start] == s[start + 1]:breakhead_len += 1start += 1# 如果扫描到结尾,说明整个串都是相间的if start == end:print(head_len)continue# 计算尾部连续长度while end > start:if s[end] == s[end - 1]:breaktail_len += 1end -= 1# 找出最大长度max_len = max(head_len, tail_len)temp_len = 1# 处理中间部分start += 1end -= 1while start < end:if s[start] == s[start + 1]:max_len = max(max_len, temp_len)temp_len = 1else:temp_len += 1start += 1# 如果首尾字符不同,可以考虑连接if s[0] != s[-1]:max_len = max(max_len, head_len + tail_len)print(max_len)except EOFError:break

算法及复杂度

  • 算法:双指针 + 贪心
  • 时间复杂度:\(\mathcal{O}(n)\) - 其中 \(n\) 为字符串长度,需要遍历一次字符串
  • 空间复杂度:\(\mathcal{O}(1)\) - 只需要常数级别的额外空间存储计数器和指针

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

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

相关文章

Adobe Photoshop 2025下载与安装

‌Photoshop 2025的安装环境要求主要包括操作系统、处理器、内存、显卡、显示器分辨率和硬盘空间等方面的具体要求。‌ 操作系统要求‌Windows‌:支持Windows 10(版本21H2)或更高版本,不支持Windows的长期服务版(LTSC)。处理器要求‌Windows‌:支持64位的多核Intel或AMD…

Capture one 2023下载与安装教程

1、安装包 扫描下方二维码关注「软知社」,后台回复【061】三位数字即可免费获取分享链接,无广告拒绝套路; 2、安装教程(建议关闭杀毒软件和系统防护)解压下载安装包,双击软件安装,弹窗安装对话框选择中文,点击确定选择‘我同意。’ 点击下一步选择安装目录,建议C盘之外…

S3FT选择性自监督微调:通过智能选择训练样本提升大模型整体表现

选择性自我监督微调(Selective Self-to-Supervised Fine-Tuning,S3FT)是一种创新的大语言模型微调方法,该方法通过部署专门的语义等价性判断器来识别训练集中模型自身生成的正确响应。在微调过程中,S3FT策略性地结合这些正确响应与剩余样本的标准答案(或其释义版本)来优…

20242935 2024-2025-2 《网络攻防实践》第二周作业

20242935 2024-2025-2 《网络攻防实践》第二周作业 网络信息收集技术 一、实验要求 (1)从www.besti.edu.cn、baidu.com、sina.com.cn中选择一个DNS域名进行查询,获取如下信息:DNS注册人及联系方式 该域名对应IP地址 IP地址注册人及联系方式 IP地址所在国家、城市和具体地理…

Xmanager 8下载与安装教程

1、安装包 扫描下方二维码关注「软知社」,后台回复【059】三位数字即可免费获取分享链接,无广告拒绝套路; 2、安装教程(建议关闭杀毒软件与本地防护设置)双击Xmanager-8.0.0055r.exe安装,弹窗安装对话框点击下一步选择‘我接受。。’,点击下一步选择安装目录D盘,点击下一…

Xftp 8软件下载与安装教程

Xftp 8中文版是一款十分强大、传输快速的FTP文件传输工具,它拥有着十分庞大的用户群体,其凭借着简单的界面、便捷的操作以及强大的功能,深受广大用户的好评与喜爱,当然它也是许许多多专业人士的必备工具之一。 由于Xftp 8是基于MS windows平台的STP和FTP传输工具,所以它不…

HarmonyOS SDK让小红书鸿蒙用户尽享原生相机的拍摄之美

小红书是深受年轻人喜爱的生活社交类社区平台,越来越多的人在小红书上分享旅行、日常、心情。近日,不少使用鸿蒙原生版小红书的细心用户已经发现,直接使用小红书拍摄照片与自己使用原相机拍摄有一样清晰美观的呈现效果。不仅如此,小红书现已支持用户直接从图库中上传动态照…

Xshell 8软件下载与安装教程

1、安装包 扫描下方二维码关注「软知社」,后台回复【057】三位数字即可免费获取分享链接,无广告拒绝套路; 2、安装教程(建议关闭杀毒软件与本地防护设置)双击Xshell-8.0.0055r.exe安装,弹窗安装对话框点击下一步选择‘我接受。。’,点击下一步选择安装目录D盘,点击下一步…

(附体验地址)大模型知识引擎:AI 助手能否助力销售技能提升?

体验地址:https://lke.cloud.tencent.com/webim_exp/#/chat/FAIMcM 腾讯云的大模型知识引擎本身定位于为企业客户及合作伙伴提供服务,因此我在探索如何最佳利用其现有功能与特点时,专注于实际应用场景的挖掘。为此,今天我搭建出了一个卖车销售话术练习助手,旨在帮助销售人…

Hyper V高级用法:优化虚拟机性能策略

在利用Hyper-V进行虚拟化部署时,优化虚拟机性能是至关重要的,这涉及到多个方面的策略和配置。以下是一些高级用法和优化策略,旨在提升虚拟机的整体性能和资源利用率:一、硬件配置优化 启用硬件虚拟化: 确保主机的CPU支持硬件虚拟化技术(如Intel VT-x或AMD-V),并在BIOS/…

Windbg初见

下载与安装在微软商店中找到Windbg即可。 这里是拼网速的时间,校园网可能有帮助。在等下载的这段时间里面我也看了一些博客,大概了解了一下windbg的用法。 不过怎么说还是得在虚拟机也下载一个,总是不能在实体机调试的。在Layout里面修改为Disassembly,这下有点od的样子了。…

No.40 JavaScript---防抖(debounce)、节流(throttle)

一、防抖 1.含义防抖严格算起来应该属于性能优化的知识,但实际上遇到的频率相当高,处理不当或者放任不管就容易引起浏览器卡死。2.从滚动条监听的例子说起<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><me…