基本的兩種方法
1、使用正則表達式。
public String removeDuplicateChars(String str)
{
return str.replaceAll("(?s)(.)(?=.*1)", "");
}
(?s) 開啟單行模式 dotall 讓. 號匹配任意字符
(.) 任意字符 并捕獲在第1組
(?=.*1) 這是斷言, 表示后面內容將是 任意個字符加上第1組所捕獲的內容 這模樣,如果這全部式子匹配到,表示,第1個捕獲組內容在字符串中,最少出現兩次,替換為 “” 空串. 進行 全局替換后, 全部字符串所出現的字符將不重復。
2、使用遍歷。
public String removeDuplicateChars(String str)
{
String[] strs = str.split("");
List<Stirng> list = new ArrayList<String>();
StringBuffer buffer = new StringBuffer();
for(Stirng s : strs)
{
if(!list.contains(s))
{
list.add(s);
buffer.append(s);
}
}
return buffer.toString();
}