LK409.最长回文字符串

news2024/11/26 0:45:23

题目描述

给定一个包含大写字母和小写字母的字符串 s ,返回 通过这些字母构造成的 最长的回文串 。

在构造过程中,请注意 区分大小写 。比如 “Aa” 不能当做一个回文字符串。
在这里插入图片描述

解题思路

有两种情况可以构成回文字符串:

1.全部字符呈偶数对出现
2.一组字符呈奇数对出现,其余的成偶数对出现。

我们既然已经明白最后会涉及到对字符串中的字符个数的奇偶性的判断,那么我们可以先利用一种映射关系将字符串中的每个字符个数统计下来
再回到本题目的具体需求:找出最大回文字符串的个数,此时我们将可以构成回文字符串的两种情况处理一下既可以得到我们该进行如下操作:

1.若判断某个字符个数是偶数则直接加上即可
2.若出现了奇数个的字符我们需要然一个奇数个数的字符保持奇数,其余的奇数个字符的奇数分别减去一,变为偶数个(解释可能不清楚,一会看代码)

其中我们发现上述中第二种情况较难处理(这也是官方答案技巧较强的一处)

我们利用*/的特性(结果为一个整数),在最后判断奇偶性时,我们设字符出现的个数为num那么num / 2 * 2得到的就确保为偶数,再将其加到一个统计个数的变量上,此时我们利用一个条件判断若有一个字符的个数为奇数同时统计个数变量为偶数我们则将统计个数的变量加一*这样我们其实就保证了构成最大回文字符串中只能有一组奇数个数的字符(若解释还比较模糊,看代码!!!)。

代码

class Solution {
    //Time Complexity: O(N)
    //Space Complexity: O(1)
    public int longestPalindrome(String s) {
        int res = 0;
        int[] count = new int[128];
        //利用映射关系统计字符个数
        for (int i = 0; i < s.length(); i++) {
            int ch = s.charAt(i);
            count[ch]++;
        }
        //判断奇偶性
        for (int num : count) {
            res += num / 2 * 2;
            //保证只存在一组奇数个数的字符
            if (num % 2 == 1 && res % 2 == 0) {
                res++;
            }
        }
        return res;
    }
}

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

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

相关文章

simulink 仿真时间 求解器 数据类型 delay模块

仿真时间&#xff0c;模型运行的时长 显示数据类型&#xff0c;改完数据类型后要run一次才能正常显示更改后的类型 delay模块&#xff0c;延时步长 综合训练 搭建一个累加器&#xff0c;每次调用1 //c语言 static int a 0; a;

一次搞懂ArrayBuffer和Unit8Array(TypedArray)和Array!

实现入职第三天&#xff0c;用到了公司自研框架里面的网络请求&#xff0c;返回的数据会被自动改成ArrayBuffer类型&#xff0c;研究了半天没明白ArrayBuffer怎么转成字符串数据&#xff0c;看了mentor发来的示例代码&#xff0c;经过一番研究也是明白了ArrayBuffer和它相关的东…

Python基础教程:读写文件IO操作

Python 是一门优秀的开发语言&#xff0c;它不仅是一种动态的脚本语言&#xff0c;还支持多种应用场景。在 Python 中&#xff0c;我们可以使用文件和 I/O 操作来读取和写入文件。它比起其他编程语言&#xff0c;使用更加方便。 1.读写文本文件 在 Python 中&#xff0c;读写…

【轴承RUL预测代码】基于DRSN(深度残差收缩网络)

DRSN&#xff08;深度残差收缩网络&#xff09;和完整Transformer&#xff08;encoderdecoder&#xff09; DRSN&#xff08;深度残差收缩网络&#xff09;模型的代码模型的打印训练与预测训练集的可视化&#xff1a;测试集的可视化&#xff1a; DRSN-TCN的效果 DRSN&#xff0…

贝叶斯与认知——读《贝叶斯的博弈》有感

关于对贝叶斯与认知问题的相关思考 一、贝叶斯定理二、贝叶斯与认知的本质三、经验的偏见四、总结 自古以来&#xff0c;人们就在思考知识来自何处&#xff0c;“冯翼惟象&#xff0c;何以识之&#xff1f;”&#xff0c;对此的思考逐渐发展成哲学的认识论分支。德国哲学家康德…

二十三种设计模式第十六篇--观察者模式

观察者模式是一种行为型设计模式&#xff0c;它建立了一种对象间的一对多依赖关系&#xff0c;使得当一个对象的状态发生变化时&#xff0c;所有依赖于它的对象都会得到通知并自动更新。这种模式可以实现对象间的松耦合通信&#xff0c;提高系统的可扩展性和灵活性。 观察者模…

开源白盒 静态代码分析对比

背景 源代码安全检测是安全开发流程&#xff08;SDL&#xff09;中非常重要的一部分&#xff0c;在58集团的CI/CD流程里面临每天几千数量级的构建及发布&#xff0c;白盒检测的自动化能力显得极为重要。白盒扫描从漏洞发现的需求转变为了需要适应企业CI/CD流程的白盒建设需求&…

Win2008 IIS TLS1.0升级到TLS1.2或TLS1.3

最近chrome和Edege浏览器已经把TLS 1.0标记为不安全了。 如果是开发网站&#xff0c;而使用的TLS 1.0&#xff0c;则直接打开不网站&#xff0c;也没有醒目的提示&#xff0c;你很难知道问题所在&#xff0c;总以为是SSL安装失败了&#xff0c;其实是TSL版本太低了。 如果是开…

密码学学习笔记(六):Hash Functions - 哈希函数2

哈希函数是怎么构成的&#xff1f; Merkle–Damgrd结构 哈希函数需要能够处理任意长度的输入。许多散列函数&#xff0c;例如MD5、SHA-1、SHA-2&#xff0c;都是由构建块&#xff08;称为压缩函数&#xff09;组成的&#xff0c;这些构建块可以处理特定的块大小&#xff0c;并…

SSM 整合 Shiro 安全框架【快速入门】

一、搭建ssm工程&#x1f349; 1.创建工程&#x1f95d; 更改web路径 创建所需目录 2.引入依赖&#x1f95d; <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"h…

LVS+Keepalived负载均衡高可用群集

目录 一、Keepalived高可用详解 1.应用场景 2.介绍和原理简介 3.主要模块和作用 二、LVSkeepalived配置实例&#xff08;抢占模式&#xff09; 1.配置NFS共享存储器 2.配置节点web服务&#xff08;两台的配置相同&#xff09; 3.配置主备LVSkeepalived负载调度器 三、非…

JAVA判断当前时间是否为节假日、周末、工作日,简单有效!

JAVA判断当前时间是否为节假日、周末、工作日 需求 有这么个需求&#xff0c;需要判断拿到的这个日期是否为节假日&#xff0c;周末&#xff0c;工作日&#xff0c;然后做剩下的操作。 话不多说&#xff0c;上代码 1.首先需要拿到节假日api 节假日API地址 2.拿到接口&…

Open3d计算点云切片

computePlane()给出三个点计算平面方程参数 设通过P1&#xff0c;P2&#xff0c;P3三点的平面方程为A(x - x1) B(y - y1) C(z - z1) 0 。化简为一般式&#xff1a;Ax By Cz D 0。 将P1(x1,y1,z1)点数值代入方程Ax By Cz D 0。 即可得到&#xff1a;Ax1 By 1 Cz1 D…

css之文字宽度自适应、width、fit、content

文章目录 效果图htmlcss解析width 效果图 html <div><div class"width_600"><div class"d_f ai_c bc_1296db padding_7 radius_8 cursor_pointer" style"width: fit-content;"><img class"width_26 height_26" …

ps通道抠图

相信我们在抠图的时候都遇到过这种问题&#xff1a; 在扣取一些像树木、毛发等类似图像的时候&#xff0c;用魔棒或者快速选择工具根本抠不完整&#xff08;图1&#xff09;&#xff0c;而且就算抠出来也是毛毛刺刺的&#xff0c;使用效果很拉跨。而通道抠图&#xff08;图2&a…

真的不想知道文档翻译在线翻译怎么弄才简单吗

从前有一个小明&#xff0c;他是一名国际商人。他需要将公司的商业计划书翻译成多种语言&#xff0c;以便在海外市场推销。但是&#xff0c;他并不会所有需要的语言&#xff0c;于是他开始寻找一种方法来进行文档翻译。终于&#xff0c;他找到了一种文档翻译的有效方法&#xf…

Dynamsoft Barcode Reader crack

Dynamsoft Barcode Reader crack SDK经过重构&#xff0c;与DynamsoftCaptureVision(DCV)体系结构集成&#xff0c;该体系结构包括&#xff1a; ImageSourceAdapter(ISA)-标准输入接口&#xff0c;用于将来自不同来源的图像数据转换为标准输入图像数据。此外&#xff0c;ISA结合…

2023第七届河南省高等学校信息安全对抗大赛-御网杯-ISCC2023线下赛-misc(详解-思路-脚本)

芜湖~ 是真累呀 原本一天的时间 硬打了一天半 还是那句话 不评价 各位道友心中自有公论 我misc手又发现一个小小的非预期 哎 没想到线下也有这种情况 欧克 以下是我自己的一些思路和解析 有什么问题或者建议随时都可以联系我 2023第七届河南省高等学校信息安全对抗大赛-御…

医疗设备中的直线导轨使用哪种润滑脂?

直线导轨属于滚动功能部件&#xff0c;看似普通&#xff0c;却是大多数医疗设备的核心功能部件之一&#xff0c;也是保障医疗设备精度的基础&#xff0c;需要具备高精度、高耐磨、高顺畅等性能&#xff0c;对生产企业的研发实力、制造工艺及技术水平提出相当大的挑战&#xff0…

计算机体系结构基础知识介绍之缓存性能的十大进阶优化之关键词优先和提前重启以减少失误处罚、合并写入缓冲区以减少惩罚(五)

优化五&#xff1a;关键词优先&#xff0c;提前重启&#xff0c;减少漏判 处理器通常一次只需要缓存块中的一个字&#xff08;word&#xff09;。不要等待整个块被加载&#xff0c;而是在请求的字到达后就立即发送给处理器&#xff0c;并让处理器继续执行&#xff0c;同时填充…