lz ?你好
目前成都創(chuàng)新互聯(lián)已為近千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、五指山網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
這個就是一個比較簡單的算法題 , 你可以自己寫
但是用Java語言就不需要了 , Java自帶泛型相關(guān)的類 , 很有用
其中TreeSet集合能自動識別添加的是否重復(fù) , 重復(fù)的將不會添加 , 很方便
以下是實(shí)現(xiàn)代碼:
import?java.util.List;
import?java.util.Scanner;
public?class?DeleteRepeated?{
private?String?str;
private?TreeSetString?noReapted;//帶有String類型的TreeSet泛型
public?DeleteRepeated()?{
Scanner?in?=?new?Scanner(System.in);
System.out.println?("輸入一個字符串:");
str?=?in.nextLine();
noReapted?=?new?TreeSet();
}
//清楚重復(fù)的數(shù)據(jù)
public?void?removeRepeated(){
for?(int?i?=?0;?i??str.length();?i++){
noReapted.add(""+str.charAt(i));
//str.charAt(i)返回的是char型??所以先加一個""空格?,?轉(zhuǎn)換成String型
//TreeSet泛型能保證重復(fù)的不加入?,?而且有序
}
str?=?"";
for(String?index:noReapted){
str?+=?index;
}
//輸出
System.out.println?(str);
}
public?static?void?main(String[]?args)?{
DeleteRepeated?dr?=?new?DeleteRepeated();
dr.removeRepeated();
}
}
運(yùn)行截圖:
希望能幫助你哈
屬性是????
先給你一個看看是不是你需要的好了,
//?利用?Set?的特性,將所有項(xiàng)目放入?Set?
//中即可移除重復(fù)的項(xiàng)目
SetString?stringSet?=?new?HashSetString();
for?(String?element?:?duplicateArray)?{
stringSet.add(element);
}
//?Set.size()?為不重復(fù)項(xiàng)目的個數(shù)
String?nonDuplicateArray[]?=?new?String[stringSet.size()];
//?將?Set?中的項(xiàng)目取出放到?nonDuplicateArray?中
Object[]?tempArray?=?stringSet.toArray();
for?(int?i?=?0;?i??tempArray.length;?i++)?{
nonDuplicateArray[i]?=?(String)?tempArray[i];
}
如果代碼能力不是很好的話可以借助一些軟件去抓取新聞的字段
把數(shù)據(jù)抓取下來以后可以選擇存入數(shù)據(jù)庫當(dāng)中
需要去重的話,在Java的集合框架中就有HashSet和HashMap可以對數(shù)據(jù)去重
使用帶Hash的集合時(shí)一定要注意,如果是存放自定義的對象一定要重寫equals方法和HashCode方法
無非就是檢查是否已經(jīng)有數(shù)據(jù)的問題,用List做可能比較簡單點(diǎn)
public?class?SigleList{
ListInteger?nums;
public?SingleList(){
nums?=?new?ArrayListInteger();
}
public?void?add(Integer?num){
if(!checkNumExist){
nums.add(num);
}
}
public?boolean?checkNumExist(Integer){
return?nums.contains(Integer);
}
}
這個SingleList就簡單實(shí)現(xiàn)了去重增加,可以用它來讀數(shù)據(jù)
public?class?Test{
public?static?void?main(String[]?args){
SingleList?nums?=?new?SingleList();
//?產(chǎn)生100個數(shù)據(jù)
for(int?i?=?0;?i++;?i??100){
//?產(chǎn)生隨機(jī)數(shù)
Integer?num?=?new?Random().nextInt(100000);
nums.add(num);
}
foreach(Integer?num?:?nums){
System.out.println(num);
}
}
}
讀取文件,把每行都存成一個字符串,放入list中,重復(fù)的就不添加,最后刪除文件,把list寫入文件。。。
ListString?list?=?new?ArrayList();
/*list.add("abc");
list.add("abc");
list.add("def");
list.add("bcd");*/
SetString?set?=?new?LinkedHashSet();//這種方式保證去重后的元素相對位置不變
//SetString?set?=?new?HashSet();//這種方式去重后元素的位置很有可能變化了
set.addAll(list);
list.clear();
list.addAll(set);
for(String?s?:?list){
System.out.println(s);
}
整個思路就是利用set中的元素是不重復(fù)的,來達(dá)到去重的目的