验证回文串

验证回文串

  • 题目描述:
    在这里插入图片描述

  • 方法一:筛选 + 判断

    • 最简单的方法是对字符串 s 进行一次遍历,并将其中的字母和数字字符进行保留,放在另一个字符串 sgood 中。这样我们只需要判断 sgood 是否是一个普通的回文串即可。
    • 判断的方法有两种。
      • 第一种是使用语言中的字符串翻转 API 得到 sgood 的逆序字符串sgood_rev,只要这两个字符串相同,那么 sgood 就是回文串。
        package VerifyPalindromeString;
        
        import java.util.Scanner;
        
        public class VerifyPalindromeString01 {
            public static void main(String[] args) {
                Scanner input = new Scanner(System.in);
                System.out.print("Enter a string: ");
                String s = input.nextLine();
                System.out.println(isPalindrome(s));
            }
            public static boolean isPalindrome(String s) {
                //两个字符串,其中一个进行翻转
                StringBuffer sgood = new StringBuffer();
                int length = s.length();
                for (int i = 0; i < length; i++) {
                    char ch = s.charAt(i);
                    if (Character.isLetterOrDigit(ch)) {
                        sgood.append(Character.toLowerCase(ch));
                    }
                }
                StringBuffer sgood_rev = new StringBuffer(sgood).reverse();
                return sgood.toString().equals(sgood_rev.toString());
            }
        }
        
        
      • 第二种是使用双指针。初始时,左右指针分别指向 sgood 的两侧,随后我们不断地将这两个指针相向移动,每次移动一步,并判断这两个指针指向的字符是否相同。当这两个指针相遇时,就说明 sgood 时回文串。
        package VerifyPalindromeString;
        
        import java.util.Scanner;
        
        public class VerifyPalindromeString02 {
            public static void main(String[] args) {
                Scanner input = new Scanner(System.in);
                System.out.print("Enter a string: ");
                String s = input.nextLine();
                System.out.println(isPalindrome(s));
            }
            public static boolean isPalindrome(String s) {
                //两个字符串,两个指针
                StringBuffer sgood = new StringBuffer();
                int length = s.length();
                for (int i = 0; i < length; i++) {
                    char ch = s.charAt(i);
                    if (Character.isLetterOrDigit(ch)) {
                        sgood.append(Character.toLowerCase(ch));
                    }
                }
                int n = sgood.length();
                int left = 0, right = n - 1;
                while (left < right) {
                    if (Character.toLowerCase(sgood.charAt(left)) != Character.toLowerCase(sgood.charAt(right))) {
                        return false;
                    }
                    ++left;
                    --right;
                }
                return true;
            }
        }
        
        
    • 复杂度分析
      • 时间复杂度:O(∣s∣),其中∣s∣ 是字符串 s 的长度。
      • 空间复杂度:O(∣s∣)。由于我们需要将所有的字母和数字字符存放在另一个字符串中,在最坏情况下,新的字符串 sgood 与原字符串s 完全相同,因此需要使用O(∣s∣) 的空间。
  • 方法二:在原字符串上直接判断

    • 我们可以对方法一中第二种判断回文串的方法进行优化,就可以得到只使用 O(1) 空间的算法。
    • 我们直接在原字符串 s 上使用双指针。在移动任意一个指针时,需要不断地向另一指针的方向移动,直到遇到一个字母或数字字符,或者两指针重合为止。也就是说,我们每次将指针移到下一个字母字符或数字字符,再判断这两个指针指向的字符是否相同。
      package VerifyPalindromeString;
      
      import java.util.Scanner;
      
      public class VerifyPalindromeString03 {
          public static void main(String[] args) {
              Scanner input = new Scanner(System.in);
              System.out.print("Enter a string: ");
              String s = input.nextLine();
              System.out.println(isPalindrome(s));
          }
          public static boolean isPalindrome(String s) {
              //一个字符串,两个指针
              int n = s.length();
              int left = 0, right = n - 1;
              while (left < right) {
                  while (left < right && !Character.isLetterOrDigit(s.charAt(left))) {
                      ++left;
                  }
                  while (left < right && !Character.isLetterOrDigit(s.charAt(right))) {
                      --right;
                  }
                  if (left < right) {
                      if (Character.toLowerCase(s.charAt(left)) != Character.toLowerCase(s.charAt(right))) {
                          return false;
                      }
                      ++left;
                      --right;
                  }
              }
              return true;
          }
      }
      
      
    • 复杂度分析
      • 时间复杂度:O(|s|),其中 |s|是字符串 s 的长度。
      • 空间复杂度:O(1)。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值