有效回文字符串(Valid palindrome)

题目描述

思路分析

代码实践

java:

java 复制代码
public class Solutation1 {
	//定义一个方法,判断是否是有效数字或者字母
	private static boolean isValid(char c) {
		//如果不是字母或者数字,那就返回一个flase
		//这里调用了Character类里面的方法
		return Character.isLetter(c) || Character.isDigit(c);
	}

	//判断两个字母是否相等,这里还要忽略大小写
	private static boolean isEqual(char a,char b) {

		return Character.toLowerCase(a) == Character.toLowerCase(b);
	}

	//主函数
	public static boolean isPalindrome(String s) {
		if (s == null) {
			return false;
		}

		int left = 0, right = s.length() - 1;
		while (left < right) {
			//非数字左边是++循环
			while (left < right && !isValid(s.charAt(left))) {
				left++;
			} 
			while (left < right && !isValid(s.charAt(right))) {
				right--;
			}
			//上面都跳到正确的位置
			//开始比较
			if (left < right && !isEqual(s.charAt(left), s.charAt(right))) {
				return false;//只要有一个对比不等就不是回文
			}
			left++;
			right--;
		}
		//上面如果没有跳到return,直接返回true
		return true;
		
	}

	public static void main(String[] args) {
		boolean res = isPalindrome("1b , 1");
		if (res == true) {
			System.out.println("它是回文串");
		}
	}
}

运行结果:

下面分析一下它的时间复杂度

所以时间复杂度是O(n)

下面用c++代码解决:

cpp 复制代码
#include <iostream>
#include <cctype> // 用于字符处理函数

using namespace std;

bool isValid(char c) {
    // 如果不是字母或者数字,返回false
    return isalnum(c);
}

bool isEqual(char a, char b) {
    // 忽略大小写比较两个字符是否相等
    return tolower(a) == tolower(b);
}

bool isPalindrome(string s) {

    if (s.empty()) {
        return true; // 空字符串被认为是回文串
    }

    int left = 0, right = s.length() - 1;
    while (left < right) {
        // 非字母或数字的字符,左指针右移
        while (left < right && !isValid(s[left])) {
            left++;
        }
        // 非字母或数字的字符,右指针左移
        while (left < right && !isValid(s[right])) {
            right--;
        }

        // 开始比较字符
        if (left < right && !isEqual(s[left], s[right])) {
            return false; // 只要有一个对比不等就不是回文
        }

        left++;
        right--;
    }

    return true;
}

int main() {
    bool res = isPalindrome("1b , 1");
    if (res == true) {
        printf("it is palindrome\n");
    } else {
        printf("it is not palindrome");
    }
    return 0;
}

运行结果:

上面说几个点:

1.这里引入了c语言当中的一个头文件,去进行字符判断的操作

2.下面这里为什么不进行NULL的判断

正确的方法来检查字符串是否为空。如果你尝试将空指针传递给这个函数,编译器会报错,因为它不接受指针作为参数。所以不需要额外检查指针是否为 NULL

上面的时间算法复杂度还是O(n)

好了祝早安午安晚安

相关推荐
bu_shuo1 分钟前
MATLAB与Simulink介绍
开发语言·matlab·simulink
吃西瓜的年年6 分钟前
5.C语言流程控制语句
c语言·开发语言
萧曵 丶7 分钟前
Java 泛型详解
java·开发语言·泛型
码上宝藏8 分钟前
从解耦到拓展:Clapper 0.10.0 插件化架构设计与 Lua 脚本集成
linux·开发语言·lua·视频播放器·clapper
qq_1171790712 分钟前
海康威视球机萤石云不在线问题解决方案
开发语言·智能路由器·php
superman超哥13 分钟前
Rust 并发性能调优:线程、异步与无锁的深度优化
开发语言·后端·rust·线程·异步·无锁·rust并发性能
csbysj202013 分钟前
Python 多线程
开发语言
superman超哥13 分钟前
Rust Trait 对象与动态分发权衡:性能与灵活性的深度权衡
开发语言·后端·rust·rust trait·对象与动态发布·性能与灵活性
ftpeak14 分钟前
Burn:纯 Rust 小 AI 引擎的嵌入式物体识别之旅(一步不踩坑)
开发语言·人工智能·rust
独断万古他化19 分钟前
【Spring Web MVC 入门实战】实战三部曲由易到难:加法计算器 + 用户登录 + 留言板全流程实现
java·后端·spring·mvc