验证回文串(LeetCode)【Java&C++】

简介: 验证回文串(LeetCode)【Java&C++】

题目

验证回文串


难度 简单


给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。


说明:本题中,我们将空字符串定义为有效的回文串。


示例 1:


输入: “A man, a plan, a canal: Panama”

输出: true

解释:“amanaplanacanalpanama” 是回文串


示例 2:


输入: “race a car”

输出: false

解释:“raceacar” 不是回文串


提示:1 <= s.length <= 2 * 105

字符串 s 由 ASCII 字符组成


代码:


class Solution {
    public boolean isPalindrome(String s) {
        //先都转小写
        s = s.toLowerCase();
        StringBuilder sCopy = new StringBuilder();
        for (int i = 0; i < s.length(); i++) {
            //自保留字母和数字
            if(Character.isLetterOrDigit(s.charAt(i))) {
                sCopy.append(s.charAt(i));
            }
        }
        //反转字符串
        StringBuffer sCopy2 = new StringBuffer(sCopy).reverse();
        //比较
        return sCopy.toString().equals(sCopy2.toString());
    }
}

C++版:


#include<bits/stdc++.h>
using namespace std;
class Solution {
public:
    bool isPalindrome(string s) {
        string str;
        for(char ch : s){
            // 只考虑字母和数字字符
            if(isalnum(ch)){
                // 将字符转换为小写
                str += tolower(ch);
            }
        }
        /**
         * c.rbegin() 返回一个逆序迭代器,它指向容器c的最后一个元素
         * c.rend() 返回一个逆序迭代器,它指向容器c的第一个元素前面的位置
         */
        string str2(str.rbegin(), str.rend());
        // 判断是否为回文串
        return str == str2;
    }
};
int main() {
    Solution s;
    cout << (s.isPalindrome("A man, a plan, a canal: Panama") ?"true":"false")<< endl;
    return 0;
}

以上就是验证回文串的全部内容

相关文章
|
7月前
|
jenkins Shell 测试技术
|
7月前
|
安全 jenkins Java
Java、Python、C++支持jenkins和SonarQube(一)
Jenkins 是一个开源的 持续集成(CI)和持续交付(CD) 工具,用于自动化构建、测试和部署软件项目。它基于 Java 开发,支持跨平台运行,并拥有丰富的插件生态系统,可以灵活地扩展功能
467 5
|
6月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
7月前
|
jenkins Java Shell
Java、Python、C++支持jenkins和SonarQube(全集)
Jenkins 是一个开源的持续集成(CI)和持续交付(CD)工具,用于自动化构建、测试和部署软件项目。它基于 Java 开发,支持跨平台运行,并拥有丰富的插件生态系统,可以灵活地扩展功能
649 1
|
7月前
|
jenkins Java 持续交付
Java、Python、C++支持Jenkins和SonarQube(三)
Python与Jenkins和SonarQube
356 1
|
7月前
|
jenkins Java 测试技术
|
10月前
|
算法 Java 数据库连接
Java 与 C++ 区别深入剖析及应用实例详解
本文深入剖析了Java和C++两种编程语言的区别,从编译与执行机制、面向对象特性、数据类型与变量、内存管理、异常处理等方面进行对比,并结合游戏开发、企业级应用开发、操作系统与嵌入式开发等实际场景分析其特点。Java以跨平台性强、自动内存管理著称,适合企业级应用;C++则因高性能和对硬件的直接访问能力,在游戏引擎和嵌入式系统中占据优势。开发者可根据项目需求选择合适语言,提升开发效率与软件质量。附面试资料链接:[点此获取](https://pan.quark.cn/s/4459235fee85)。
833 0
|
Java Android开发 C++
Java和C++
Java和C++
313 15
|
IDE Java 程序员
C++ 程序员的 Java 指南
一个 C++ 程序员自己总结的 Java 学习中应该注意的点。
185 5
WK
|
安全 Java 编译器
C++和Java哪个更好用
C++和Java各具优势,选择取决于项目需求、开发者偏好及目标平台特性。C++性能出色,适合游戏、实时系统等;Java平台独立性强,适合跨平台、安全敏感应用。C++提供硬件访问和灵活编程范式,Java有自动内存管理和丰富库支持。两者各有千秋,需根据具体需求选择。
WK
509 1
下一篇
开通oss服务