L2-008 最长对称子串(java题解)

对给定的字符串,本题要求你输出最长对称子串的长度。例如,给定Is PAT&TAP symmetric?,最长对称子串为s PAT&TAP s,于是你应该输出11。

输入格式:
输入在一行中给出长度不超过1000的非空字符串。

输出格式:
在一行中输出最长对称子串的长度。

输入样例:
Is PAT&TAP symmetric?
输出样例:
11

分析

1.只有 一个字符的时候,返回1.
2.abba
3.abcba

代码

import java.util.Scanner;public class LongSubStr {private static int getSum(char[] arr, int left, int right) {int sum = 0;while (arr[left]== arr[right]){sum +=2;left--;right++;if(left <0|| right > arr.length-1){break;}}return sum;}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);String str = scanner.nextLine();char[] arr = str.toCharArray();if(arr.length == 1){System.out.println(1);return;}int max = -1;for(int i = 0; i < arr.length; i++){if(i+1>arr.length-1){continue;}if(arr[i]!=arr[i+1])//abcba{int left = i - 1;int right = i + 1;if(left<0||right>arr.length-1){continue;}int sum = getSum(arr, left, right)+1;if(max<sum){max = sum;}}else//abba{int left = i;int right = i + 1;if(left<1||right>arr.length-1){continue;}int sum = getSum(arr, left, right);if(max<sum){max = sum;}}}System.out.println(max);}}

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

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

相关文章

JavaScript 中的 sort 传入 (a,b) => b - a 会是升序还是降序?为什么呢?

在 JavaScript 中的数组有内建的 sort 方法,可以让我们不用自己手写排序算法,也能够有高效能的排序方法可用。然而,你知道sort 要怎么用吗? 在sort 中要传入的compareFn 又是如何运作的? 当compareFn 是(a, b) => b - a 时,排序会是升序还是降序? 为什么呢? 这一连…

用户登录问题——登录态

不论在任何系统中&#xff0c;用户体系都是重中之重&#xff0c;而怎么建立一个完善的&#xff0c;安全的用户体系&#xff0c;是所有开发者都在思考的问题。 而这里就来思考一下&#xff0c;用户登录问题。 登录的作用主要就是用户认证&#xff0c;与权限认证&#xff0c;也…

云原生周刊:CNCF 宣布 Falco 毕业|2024.3.4

开源项目推荐 ldap-operator 用于部署和管理 LDAP 目录的 Kubernetes Operator。 Updatecli Updatecli 是一个用于应用文件更新策略的工具。每个应用程序“运行”时都设计为可在任何地方使用&#xff0c;它会检测是否需要使用自定义策略更新值&#xff0c;然后根据该策略应…

UOS 与 Ubuntu 命令行打开安装包界面,双击打开界面调用安装包界面展示

UOS 使用deepin-deb-installer安装程序 deepin-deb-installer xxxxxxx.deb & Ubuntu snap-store --local-filename /home/seven/wps-office_1xxxxxxx.deb &

ubuntu20.04安装ros并配置相关环境以及驱动AUBO i5机械臂

ubuntu20.04安装ros并配置相关环境以及驱动AUBO i5机械臂 安装ros安装rosdep(小鱼的rosdepc,又快又好用)环境配置下载并编译aubo roslib库环境变量配置aubo gazeboaubo rviz驱动真实机械臂 安装ros 搜索鱼香ros网站https://fishros.com/&#xff0c;根据一键安装ros里提供的指…

【数据结构】二、线性表:1.顺序表的定义与实现(静态分配、动态分配)

文章目录 线性表linear list基本操作1.顺序表1.1静态分配1.2动态分配 线性表linear list 线性表是具有相同数据类型的n (n≥0&#xff09;个数据元素的有限序列&#xff0c;其中n为表长&#xff0c;当n0时线性表是一个空表。 若用L命名线性表&#xff0c;则其一般表示为&#…

自动填充MyBatis-Plus日志中的sql语句参数小工具

写在前面&#xff1a;大家好&#xff01;我是晴空๓。如果博客中有不足或者的错误的地方欢迎在评论区或者私信我指正&#xff0c;感谢大家的不吝赐教。我的唯一博客更新地址是&#xff1a;https://ac-fun.blog.csdn.net/。非常感谢大家的支持。一起加油&#xff0c;冲鸭&#x…

Chromium内核浏览器编译记(四)Linux版本CEF编译

转载请注明出处&#xff1a;https://blog.csdn.net/kong_gu_you_lan/article/details/136508294 本文出自 容华谢后的博客 0.写在前面 本篇文章是用来记录编译Linux版本CEF的步骤和踩过的坑&#xff0c;以防止后续再用到的时候忘记&#xff0c;同时也希望能够帮助到遇到同样问…

Crow 编译和环境搭建

Crow与其说是编译&#xff0c;倒不如说是环境搭建。Crow只需要包含头文件&#xff0c;所以不用编译生成lib。 Crow环境搭建 boost&#xff08;可以不编译boost&#xff0c;只需要boost头文件即可&#xff09;asio &#xff08;可以不编译&#xff0c;直接包含头文件。不能直接…

【Linux】软件管理器yum和编辑器vim

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 文章目录 一、Linux下安装软件的方案1.1 源代码安装1.2 rpm安装1.3 yum安装 二、Linux软件…

Spring Boot 配置热部署

前言 对于 Spring Boot 项目之中, 在刚开始学习的时候, 每当代码进行变动的时候, 想要生效那就必须要手动重启. 为什么要重启呢 ? 原因在于写的代码是依靠运行之后的 class 文件运行的, 当我们的代码更新以后, 如果不去手动重启, 那么就无法生成新的 class 文件, 执行的就是旧…

C#关键字学习

前言 记录C#编程中用到的关键字&#xff0c;对关键字的用途进行解释、记录、学习。会持续更新。 1. volatile 在C#中&#xff0c;volatile关键字用于声明一个字段&#xff08;通常是一个共享的字段&#xff09;是易变的&#xff0c;即每次访问该字段时&#xff0c;都要从内存…

蓝桥杯物联网竞赛_STM32L071_11_知识体系的查漏与补缺

太久没学单片机了&#xff0c;再重新过一遍查漏补缺&#xff0c;对其中之前没怎么在意的&#xff0c;而现在又发觉的问题进行再分析与补充 1. debug serial wire是干什么用的 这个东西我勾选不勾选都对我的程序没有什么影响&#xff0c;我很好奇是干什么用的&#xff0c;网上查…

vue3+elementPlus:el-table-column表格列动态设置单元格颜色

:cell-style属性 //html<el-tableempty-text"暂无数据":data"datalist.table":max-height"height"row-key"id"border:cell-style"cellStyle"> <el-table>//js //动态设置单元格颜色 const cellStyle ({ row, c…

Java后台面试相关知识点解析

文章目录 JavaJava中四种引用类型及使用场景集合HashMap源码及扩容策略HashMap死循环问题ConcurrentHashMap与HashtableConCurrentHashMap 1.8 相比 1.7 判断单链表是否有环&#xff0c;并且找出环的入口IO线程池线程池的几种创建方式判断线程是否可以回收线程池的7大核心参数线…

Golang 常用的时间转换

1、获取 Y-m-d H:i:s 格式的当前时间 t : time.Now().Format(time.DateTime) 2、获取当前时间戳 currentTime : time.Now() timestamp : currentTime.Unix() // 获取秒级时间戳 3、Y-m-d H:i:s 格式转时间戳 timeStr : "2023-09-01 12:00:00" t, err : time.Par…

matlab 仿真IIR低通滤波器,显示滤波前后的波形和频谱

figure fs500;%采样率 f130;%信号频率 f270;%信号频率 f3 100;%信号频率 f4 150;%信号频率 T2;%时宽2s nround(T*fs);%采样点个数 tlinspace(0,T,n);%时域横坐标 x sin(2*pi*f1*t) sin(2*pi*f2*t) sin(2*pi*f3*t) 2*cos(2*pi*f4*t); subplot(221); plot(t,x);%画时域图 xl…

【MySQL】lower_case_table_names作用及使用

知识点&#xff1a; lower_case_table_names 是mysql设置大小写是否敏感的一个参数。 场景&#xff1a;在使用dataease时&#xff0c;连接外部数据库&#xff0c;启动报错&#xff01;后查看官方文档&#xff0c;特别要求改数据库配置文件&#xff1a;lower_case_table_names …

Mybatis从入门到CRUD到分页到日志到Lombok到动态SQL再到缓存

Mybatis 入门 1.导入maven依赖 <dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>x.x.x</version> </dependency>2.配置核心文件 <?xml version"1.0" encoding"U…

【MySQL知识体系】第1章 初始 MySQL

文章目录 第1章 初始 MySQL1.1 MySQL 介绍1.1.1 什么是 MySQL&#xff1f;1.1.2 MySQL 的特点&#xff1f;1.1.3 MySQL 默认端口&#xff1f; 1.2 安装 MySQL1.2.1在MacOS上安装MySQL1.2.2 在Windows上安装MySQL 1.3 如何选择 MySQL 客户端1.3.1 在MacOS上安装Workbench1.3.2 在…