<一>替换空格
public class Solution { public String replaceSpace(StringBuffer str) { int len = str.length(); StringBuffer res = new StringBuffer(); for(int i = 0;i < len;i++){ if(str.charAt(i) != ‘ ‘){ res.append(str.charAt(i)); }else{ res.append("%20"); } } return res.toString(); }
<二>正则表达式匹配
public class Solution { public boolean match(char[] str, char[] pattern) { if((null == str && null == pattern) || (null != str && pattern == null)){ return true; } if(null == str && pattern != null){ return false; } return modeoMatch(str,pattern,0,0); } private boolean modeoMatch(char[] str,char[] pattern,int slen,int plen){ if(slen == str.length && plen == pattern.length){ return true; } if(slen != str.length && plen == pattern.length){ return false; } if(plen + 1 < pattern.length && pattern[plen + 1] == ‘*‘){ if(slen < str.length && (str[slen] == pattern[plen] || pattern[plen] == ‘.‘)){ return modeoMatch(str,pattern,slen + 1,plen) || modeoMatch(str,pattern,slen,plen + 2); }else{ return modeoMatch(str,pattern,slen,plen + 2); } } //必须放在后面,因为从后面的先判断才对 if(slen < str.length && (str[slen] == pattern[plen] || pattern[plen] == ‘.‘)){ return modeoMatch(str,pattern,slen + 1,plen + 1); } return false; } }
<三>表示数值的字符串
public class Solution { private int index = 0; public boolean isNumeric(char[] str) { if(str.length <= 0){ return false; } boolean flag = scanInteger(str); if(index < str.length && str[index] == ‘.‘){ index++; flag = scanInteger(str) || flag; } if(index < str.length && (str[index] == ‘E‘ || str[index] == ‘e‘)){ index++; flag = flag && scanInteger(str); } return flag && index == str.length; } private Boolean scanInteger(char[] str){ //加减符号后面该出现的 if(index < str.length && (str[index] == ‘+‘ || str[index] == ‘-‘)){ index++; } int start = index; //Character.isDigit(str[index]) 相同与 str[index] >= ‘0‘ && str[index] <= ‘9‘ while(index < str.length && str[index] >= ‘0‘ && str[index] <= ‘9‘){ index++; } return start < index; } }
<四>字符流中第一个不重复的字符
如果当前字符流没有存在出现一次的字符,返回#字符。
代码如下:
import java.util.HashMap; import java.util.ArrayList; public class Solution { HashMap<Character,Integer> map = new HashMap<Character,Integer>(); ArrayList list = new ArrayList(); //Insert one char from stringstream public void Insert(char ch) { if(!map.containsKey(ch)){ map.put(ch,1); list.add(ch); }else{ map.put(ch,map.get(ch) + 1); } } //return the first appearence once char in current stringstream public char FirstAppearingOnce() { for(int i = 0;i < list.size();i++){ if(map.get(list.get(i)) == 1){ return (char)list.get(i); } } return ‘#‘; } }
原文:https://www.cnblogs.com/youdiaodaxue16/p/11374567.html