• 验证回文串的一点解题思路


    回文串,就是说给出的字符串中的字符是否对称,即:第一个字符与最后一个字符相等,第二个字符等于倒数第二个字符,以此类推,忽略大小写以及标点符号。

    e.g:

    A man, a plan, a canal: Panama =====>>>>输出应为true

    race a car ======>>>>输出应为false

    这道题,在看清楚题目要求之后,其实就可以有解题的思路了。忽略大小写,那直接把字符串全都转换为小写就可以了(大写也可以啦只要喜欢就好),这样在后面的判断语句中就可以写的比较
    单。
    另外,我个人是比较偏爱数组的,对字符串比较不感冒,所以我在这里就用一个char数组来存储这个字符串并进行操作。比如说剔除一些空格或者标点符号等一些奇奇怪怪的东西。

    (貌似用string的split()方法也可以??菜鸡一个,并不是很清楚)在剔除这些东西之后就可以用一个for循环来遍历这个char数组并且对其中的元素
    进行比较了。
    代码如下:
    class Solution {
        public boolean isPalindrome(String s) {
            int length = s.length();
            String s1 = s.toLowerCase();
            char[] ch = s1.toCharArray();
    //题目所说,空的字符串当成一个有效的回文串
    if(s.isEmpty()) { return true; }
    //如果长度只有1的话,无论如何它的逆序都等于它本身
    if(length == 1) { return true; } int count = 0; //用于记录符合条件的字符数目 int index = 0; for(char c:ch) { if((c>='a'&&c<='z')||(c>='0'&&c<='9')) { count++; } }
    //如果全部是一些奇奇怪怪的东西,虽然看起来极度奇怪,但题目说它是有效的回文串我也没有办法啊摊手
    if(count == 0) { return true; } else { char[] ch1 = new char[count]; for(char c:ch) { if((c>='a'&&c<='z')||(c>='0'&&c<='9')) { ch1[index] = c; index++; } }
    /**
    *在这里其实可以创建两个字符串,然后把操作过后的char数组以及char数组的逆序赋值给这两个字符串,如果两个字符串相等的话则证明给出的字符串是回文串。
    *不过我感觉这个方法其实更次,时间并不会减少,而且内存还增加了
    **/
    for(int i=0,j=count-1; i<=j; i++,j--) { if(ch1[i]!=ch1[j]) { return false; } } } return true; } }

    这段代码运行的时间和占用的内存好像并不稳定,试过提交几次得到的结果都并不相同。在最后的循环判断那里,虽然我只是觉得注释所说的方法所需要的时间更长,但毕竟没有真正运行比较过,所以说不定,有机会的话要试一下效果(说说罢了,并不会试)

  • 相关阅读:
    CentOS7和Ubuntu18.10下运行Qt Creator出现cannot find -lGL的问题的解决方案
    C++中使用CMake编译管理项目
    C++ std::isnan等函数的使用
    七个开源的 Spring Boot 前后端分离项目,一定要收藏!
    基于Select模型的Windows TCP服务端和客户端程序示例
    简单的C++11线程池实现
    Windows下FFMEPG编译
    MIMO431学习笔记目录
    golang调用海康sdk
    GRPC-go版本
  • 原文地址:https://www.cnblogs.com/WakingShaw/p/11144599.html
Copyright © 2020-2023  润新知