(Java)判断回文串,忽略既非字母又非数字的字符
来源:互联网 发布:华广软件套餐 编辑:程序博客网 时间:2024/05/20 23:39
问题:检测字符串是否为回文串,不计非字母和数字的字符
解决:
1、通过删除非字母非数字的字符来过滤字符串
创建空字符串缓冲区,将字符串中每个字母和数字字符添加到字符缓冲区中,再从缓冲区中返回字符串,可以使用Character类中的isLetterOrDigit(ch)方法检测字符ch是否为字母数字。
2、倒置过滤后的字符串得到一个新的字符串,使用equals()方法比较倒置后字符串和过滤后字符串内容是否相等。
程序清单:CheckHuiwenStringIgnoreNotLetterAndDidgit.java
//忽略既非字母又非数字的数字的字符,判断回文串public class CheckHuiwenStringIgnoreNotLetterAndDidgit {public static void main(String[] args) {String s="a?b2c\\d1e1%dc/2ba";System.out.println("is "+"["+s+"]"+" 回文串?"+"--"+isHuiwen(s));String ss="12?abc(ba12";System.out.println("is "+"["+ss+"]"+" 回文串?"+"--"+isHuiwen(ss));}public static boolean isHuiwen(String s){String s1=filter(s);String s2=reverse(s1);return s2.equals(s1);}public static String filter(String s){//删除非字母非数字的字符过滤字符串StringBuffer strBuf=new StringBuffer();for(int i=0;i<s.length();i++){if(Character.isLetterOrDigit(s.charAt(i)))strBuf.append(s.charAt(i));}return strBuf.toString();}public static String reverse(String s){//过滤后字符串反转,返回新的字符串StringBuffer strBuf=new StringBuffer(s);strBuf.reverse();return strBuf.toString();}}
- (Java)判断回文串,忽略既非字母又非数字的字符
- 判断文本框中输入的(禁止客户输入非字母或非数字)
- 正则表达式怎么匹配非汉字非字母非数字之外的字符
- java 过滤非数字字符
- 替换非字母数字汉字空格外其他字符的SQL语句
- 给定一个字符串,确定它是否是回文,只考虑字母数字字符和忽略大小写。
- 判断字母汉字数字的字符长度
- mysql 过滤查询(以字母开头,以数字开头,非数字开头,非字母开头)
- Leetcode051--判断回文数(忽律大小写和非字符)
- 【leetcode】对撞指针应用之回文字符串判断(忽略大小写,以及出数字外其他字符)
- JS 屏蔽非数字字符的输入
- leetcode_125. Valid Palindrome 判断字母数字回文串,大小写转化
- 编写程序从键盘上输入一些字母和数字,统计显示其中的数字字符的个数和非数字字符个数。
- 判断某个字段里是否含有非数字字符
- 编写变态的(非字母数字的)PHP后门
- 正则表达式类判断字符串内是否有非数字的字符
- 关于"密码最短长度为7,其中必须包含以下非字母数字字符: 1”的问题
- java 判断一个字符中字母数字个数
- Android 画图方式总结
- 回溯法:N后问题
- Boost asio async_accept memory leak问题分析
- android Intent匹配,自定义action data category
- struts 多语言配置
- (Java)判断回文串,忽略既非字母又非数字的字符
- WordPress中文标签伪静态设置方法,以及为什么出错?
- oracle实现对表dml错误记录日志
- 使用NSOperationQueue简化多线程开发
- 我妈要是知道这些,我早上北大了。
- ubuntu12.04 安装Gearman及其php扩展
- 鼠标经过隐藏图片显示文字
- 北京地铁
- Oracle 端口