NB15 牛群编号的回文顺序II

news/2024/11/14 3:14:03/

原题链接

牛群编号的回文顺序II_牛客题霸_牛客网 (nowcoder.com)

一种可行的思路

这道题是 NB14 的升级, 大家可以看看我关于 NB 14 的题解NB14 牛群编号的回文顺序

先遍历链表, 将节点的值(1-9)用 StringBuffer 给存起来, 再用一个list来存每个节点

动态规划来解题

然后再用 dp 来解题
填表的时候 更新最长回文子串的起始下标和结束下标

填完表后, 看看这个最长字串的长度是否和原来的链表一样长, 是就返回空

否则 把ist结束下标上的节点指向空

再返回起始下标上的节点

状态转移方程为:

dp[i][j] = dp[i + 1][j - 1] && strB[i] == strB[j] (i > j + 1)
dp[i][j] = true; (i = j)
dp[i][j] = strB[i] == strB[j] (i + 1 = j)

填表顺序

因为 (i + 1, j - 1) 在 (i, j) 的左下角, 而且 i 必然不大于 j 所以我们 从左上到右下 斜着填表

\>   \>\>   \>\>   \>

贴个代码

java">public class Solution {public ListNode maxPalindrome (ListNode head) {List<ListNode> list = new ArrayList<>();StringBuffer strB = new StringBuffer();int start = -1, end = -1;while (head != null) {strB.append(head.val);list.add(head);head = head.next;}int len = strB.length();int maxLen = 0;boolean[][] dp = new boolean[len][len];dp[0][0] = true;for (int k = 0; k < len; k++) {for (int i = 0; i + k < len; i++) {int j = i + k;if (i == j) dp[i][j] = true;else if (i + 1 == j) dp[i][j] = strB.charAt(i) == strB.charAt(j);else dp[i][j] = strB.charAt(i) == strB.charAt(j) && dp[i + 1][j - 1];if(dp[i][j] && j - i + 1 > maxLen) {start = i;end = j;    }}}if(end - start + 1 == list.size()) return null;list.get(end).next = null;return list.get(start);}
}

具体代码参上

好的!本次分享到这就结束了
如果对铁汁你有帮助的话,记得点赞👍+收藏⭐️+关注➕
我在这先行拜谢了:)


http://www.ppmy.cn/news/1436694.html

相关文章

javaEE初阶——多线程(九)——JUC常见的类以及线程安全的集合类

T04BF &#x1f44b;专栏: 算法|JAVA|MySQL|C语言 &#x1faf5; 小比特 大梦想 此篇文章与大家分享多线程专题的最后一篇文章:关于JUC常见的类以及线程安全的集合类 如果有不足的或者错误的请您指出! 目录 3.JUC(java.util.concurrent)常见的类3.1Callable接口3.2 RentrantLoc…

Java23种设计模式-结构型模式之桥接模式

桥接模式&#xff08;Bridge Pattern&#xff09;&#xff1a;将抽象部分与它的实现部分分离&#xff0c;使它们都可以独立地变化。 通常以下角色&#xff1a; 角色1.抽象类&#xff08;Abstraction&#xff09;&#xff1a;定义抽象接口。 角色2.扩展抽象类&#xff08;Refin…

MySQL从安装、配置到日常操作和管理的关键步骤

MySQL是一款广泛使用的开源关系型数据库管理系统&#xff0c;用于存储、管理、检索和处理数据。以下是一个详细的MySQL使用教程&#xff0c;包括安装、基本操作、数据管理、权限控制、备份与恢复等方面的内容&#xff1a; 一、MySQL安装 下载&#xff1a; 访问MySQL官方网站&a…

打开IIS网站网页错误提示Argument ‘Key must not be null‘ cannot be null.解决方案 Oracle数据库监听

打开网页异常如下&#xff1a; /“应用程序中的服务器错误。 Argument Key must not be null cannot be null.参数名:Key must not be null 客户端 连接oracle 提示&#xff1a;ORA-12541:TNS:无监听程序 按组合键WindowsR&#xff0c;打开运行 输入命令&#xff1a;lsnrctl s…

draw.io: 开启图表绘制的无限可能

图表是沟通和呈现复杂信息的有效工具&#xff0c;在工作、学习甚至生活中都有广泛的应用。作为一款在线图表软件&#xff0c;draw.io提供了简单、直观又功能丰富的界面&#xff0c;让任何人都可以轻松创建专业水准的图表。接下来&#xff0c;我将分享我深入使用draw.io的经验&a…

springboot如何返回中文json,保证顺序。LinkedHashMap应用实例

在业务中有时候需要中文json去进行映射到有些UI上&#xff0c;而springboot都是英文字段 //通过id查询消火栓的基本信息和检测值给POIGetMapping("/queryPOIForHydrant")ApiOperationSupport(order 4)ApiOperation(value "查询所需要的消火栓数据渲染给POI&qu…

网络安全的守护者:防火墙的五个主要功能解析

防火墙是一种网络安全设备&#xff0c;用于保护计算机网络免受未经授权的访问、攻击和恶意软件的侵害。它通过监控、过滤和控制网络流量&#xff0c;实施安全策略&#xff0c;防止不安全的数据包进入或离开受保护的网络。 防火墙的五个主要功能&#xff1a; 1. 访问控制&#…

锁的封装和RAII实现

RAII&#xff08;Resource Acquisition Is Initialization&#xff09;是一种 C 中的编程技术&#xff0c;它利用了对象的生命周期和析构函数的特性来管理资源的获取和释放。在 RAII 中&#xff0c;资源的获取和释放都与对象的生命周期相关联&#xff0c;资源在对象构造时被获取…