重複する値を削除する方法を教えてください。
String s="Bangalore-Chennai-NewYork-Bangalore-Chennai";
出力は次のようになります
String s="Bangalore-Chennai-NewYork-";
javaを使用しています。
どんな助けでもいただければ幸いです。
これは1行でそれを行います:
_public String deDup(String s) {
return new LinkedHashSet<String>(Arrays.asList(s.split("-"))).toString().replaceAll("(^\\[|\\]$)", "").replace(", ", "-");
}
public static void main(String[] args) {
System.out.println(deDup("Bangalore-Chennai-NewYork-Bangalore-Chennai"));
}
_
出力:
_Bangalore-Chennai-NewYork
_
順序が保持されていることに注意してください:)
キーポイントは次のとおりです。
split("-")
は、配列としてさまざまな値を提供しますArrays.asList()
は配列をリストに変換しますLinkedHashSet
は一意性を保持しますおよび挿入順序-コンストラクターを介して渡される一意の値を提供するすべての作業を実行しますtoString()
は_[element1, element2, ...]
_ですreplace
コマンドは、toString()
から「句読点」を削除しますこのソリューションでは、値に文字シーケンス_", "
_が含まれていない必要があります。これは、このような簡潔なコードの妥当な要件です。
もちろん、それは1行です:
_public String deDup(String s) {
return Arrays.stream(s.split("-")).distinct().collect(Collectors.joining("-"));
}
_
順序の保持を気にしない場合(つまり、最初の重複の発生を削除しても問題ありません):
_public String deDup(String s) {
return s.replaceAll("(\\b\\w+\\b)-(?=.*\\b\\1\\b)", "");
}
_
public static String removeDuplicates(String txt, String splitterRegex)
{
List<String> values = new ArrayList<String>();
String[] splitted = txt.split(splitterRegex);
StringBuilder sb = new StringBuilder();
for (int i = 0; i < splitted.length; ++i)
{
if (!values.contains(splitted[i]))
{
values.add(splitted[i]);
sb.append('-');
sb.append(splitted[i]);
}
}
return sb.substring(1);
}
使用法:
String s = "Bangalore-Chennai-NewYork-Bangalore-Chennai";
s = removeDuplicates(s, "\\-");
System.out.println(s);
プリント:
Bangalore-Chennai-NewYork
文字列をHashSetに追加できます。
シンペット:
Set<String> set = new HashSet<String>();
for(int i=0; i < arr.length; i++){
if(set.contains(arr[i])){
System.out.println("Duplicate string found at index " + i);
} else {
set.add(arr[i]);
}
ただのアイデア:
Collection
にロードしますCollection
を繰り返し、重複を消去しますCollection
を使用して新しい文字列を作成します最もトリッキーな部分は3である必要がありますが、不可能ではありません。 Set
を使用する場合は、この手順をスキップできます。
[〜#〜] edit [〜#〜]要素を追加する前に2&3をプレゼンスチェックに置き換えることができるかもしれません
-
で分割して文字列の配列を作成し、そこからhashSetを作成します。
String s="Bangalore-Chennai-NewYork-Bangalore-Chennai";
String[] strArr = s.split("-");
Set<String> set = new HashSet<String>(Arrays.asList(strArr));
文字列配列として戻したい場合は、次のようにします。
String[] result = new String[set.size()];
set.toArray(result);
これを行うためのサンプルコードは次のとおりです。
String s="Bangalore-Chennai-NewYork-Bangalore-Chennai";
String[] strArr = s.split("-");
Set<String> set = new LinkedHashSet<String>(Arrays.asList(strArr));
String[] result = new String[set.size()];
set.toArray(result);
StringBuilder res = new StringBuilder();
for (int i = 0; i < result.length; i++) {
String string = result[i];
if(i==result.length-1)
res.append(string);
else
res.append(string).append("-");
}
System.out.println(res.toString());
出力:-
Bangalore-Chennai-NewYork
static String RemoveDuplicateCharInString(String s){
for (int i = 0; i < s.length(); i++) {
if((s.substring(i+1)).indexOf(s.charAt(i))!=-1){
s=s.substring(0,i+1)+(s.substring(i+1)).replaceAll(""+s.charAt(i),"");
}
}
return s;
}
public class RemDuplicateWordFromString {
public static void main(String[] args) {
String s1 = "Hello India Hello India Hello India Hello India";
countWords(s1);
}
public static void countWords(String s1) {
String[] s2 = s1.split(" ");
for (int i = 0; i < s2.length; i++) {
for (int j = i + 1; j < s2.length; j++) {
if (s2[i].equals(s2[j])) {
if (i != j) {
s2[i] = "";
}
}
}
}
for (int i = 0; i < s2.length; i++) {
if (s2[i] != "") {
System.out.print(s2[i] + " ");
}
}
}
}
StringBuilder builderWord = new StringBuilder(Word);
for(int index=0; index < builderWord.length(); index++) {
for(int reverseIndex=builderWord.length()-1; reverseIndex > index;reverseIndex--) {
if (builderWord.charAt(reverseIndex) == builderWord.charAt(index)) {
builderWord.deleteCharAt(reverseIndex);
}
}
}
return builderWord.toString();
wordsArray = s.split("-");
List<String> wordsList = new Arrays.asList(wordsArray);
Set<String> wordsSet = new LinkedHashSet<String>(wordsList);
String[] noDuplicates = new String[wordsSet.size()];
wordsSet.toArray(noDuplicates);
上記のすべてよりも単純なこれが好きです。
public void removeDuplicates() {
String myString = "Bangalore-Chennai-NewYork-Bangalore-Chennai";
String[] array = myString.split("-");
Set<String> hashSet = new HashSet<String>(Arrays.asList(array));
String newString = StringUtils.join(hashSet, "-");
}
public static void main(String[] args) {
String str="Bangalore-Chennai-Newyork-Bangalore-Chennai";
String output="";
String [] arr=str.split("-");
LinkedHashSet<String> lhs=new LinkedHashSet<String>();
for (int i = 0; i < arr.length; i++) {
lhs.add(arr[i]);
}
for(String s:lhs){
output=output+s+"-";
}
System.out.println(output);
}
ゲームに少し遅れましたが、私は単にHashMapを使用します。理解しやすく、キーをすばやく検索できます。最善の方法ではないかもしれませんが、それでもIMOの良い答えです。すばやく汚いフォーマットが必要なときはいつもそれを使用しています:
String reason = "Word1 , Word2 , Word3";
HashMap<String,String> temp_hash = new HashMap<String,String>();
StringBuilder reason_fixed = new StringBuilder();
//in:
for(String Word : reason.split(",")){
temp_hash.put(Word,word);
}
//out:
for(String words_fixed : temp_hash.keySet()){
reason_fixed.append(words_fixed + " , ");
}
//print:
System.out.println(reason_fixed.toString());