华为-on练习--重复的字符过滤

it2025-09-06  69

称号:

请写一个字符串过滤程序,如果使用多个相同的字符出现在字符串中,字符首次出现在非过滤,。

 比方字符串“abacacde”过滤结果为“abcde”。 演示样例  输入:“deefd”        输出:“def” 输入:“afafafaf”     输出:“af” 输入:“pppppppp”     输出:“p”   分析: 看到这样的类似的同样字符过滤。使用java的话我们第一个想到的应该就是set这个集合,这个集合可以有效的处理掉反复的元素。 接下来就是顺序问题了,这里是保持字符原有的顺序,所以我们得选用一个实现set的类来存储这些字符。 没错LinkedHashSet可以非常好的解决我们的问题。接下来就是写程序的事了

代码例如以下:

package com.wenj.test; import java.util.Iterator; import java.util.LinkedHashSet; import java.util.Set; /**  * 题目:     请编写一个字符串过滤程序。若字符串中出现多个同样的字符,将非首次出现的字符过滤掉。     比方字符串“abacacde”过滤结果为“abcde”。     演示样例       输入:“deefd”        输出:“def”     输入:“afafafaf”     输出:“af”     输入:“pppppppp”     输出:“p”     * @author wenj91-PC  *  */ public class TestStrFilter {     public static void main(String args[]){         String strIn = "pppppppp";         TestStrFilter ts = new TestStrFilter();         System.out.println(ts.strFilter(strIn));     }          public String strFilter(String strIn){         String strTemp = strIn;         char[] str2C = strTemp.toCharArray();                  Set<Character> cs = new LinkedHashSet<Character>();         for(int i=0; i<str2C.length; i++){//利用set实现字符过滤             cs.add(str2C[i]);         }                  String temp = "";         for(Iterator<Character> it=cs.iterator(); it.hasNext(); ){//又一次组合字符串             temp += it.next();         }                  return temp;     } }

版权声明:本文博主原创文章。博客,未经同意不得转载。

转载于:https://www.cnblogs.com/bhlsheji/p/4848909.html

最新回复(0)