问题描述
判断一个字符串是否是回文。如果将字符串中所有的非字符或数字移除后,从前往后和从后往前读是一样的,则为回文。
示例
示例1
Input: s = “A man, a plan, a canal: Panama”
Output: true
Explanation: “amanaplanacanalpanama” is a palindrome.
示例2
Input: s = “race a car”
Output: false
Explanation: “raceacar” is not a palindrome.
示例3
Input: s = “ “
Output: true
Explanation: s is an empty string “” after removing non-alphanumeric characters.
Since an empty string reads the same forward and backward, it is a palindrome.
解决方案描述
设定两个变量(i,j),一个返回变量并初始化为真。
两个变量(i,j) 一个从前往后走,一个从后往前走,当i小于j时,循环下面的操作:
- 判断i所指向的是否数字或字符,如果不是的话,将i加1,结束本次循环。
- 判断j所指向的是否数字或字符,如果不是的话,将j减1,结束本次循环。
- 将i和j指向的字符转换为小写字符,并判断是否相同,如果不相同,则将返回变量设为假并跳出循环。
- 将i加1,j减1。
返回返回变量。
具体代码见下面的链接

该文介绍了如何使用C#编程语言来判断一个字符串是否为回文。方法涉及去除非字母和数字字符,然后比较字符串正反向读取的是否一致。通过设定双指针i和j,分别从两端向中间遍历,检查字符并忽略非字母数字的部分,直到找到不匹配的字符或两指针相遇,确定字符串是否为回文。
516

被折叠的 条评论
为什么被折叠?



