java 查找list中重復(fù)數(shù)據(jù)實(shí)例詳解
java 查找list中重復(fù)數(shù)據(jù)實(shí)例詳解
需求:
查找一個(gè)List集合中所有重復(fù)的數(shù)據(jù),重復(fù)的數(shù)據(jù)可能不止一堆,比如:aa, bb, aa, bb, cc , dd, aa這樣的數(shù)據(jù)。如果有重復(fù)數(shù)據(jù),則給這些重復(fù)數(shù)據(jù)加上編號,上述數(shù)據(jù)改為:aa1, bb1, aa2, bb2, cc, dd.
算法如下:
public static void same(List<String> list) { String [] indexArr ; Map<String, String> map = new HashMap<String, String>(); for (int i = 0; i < list.size(); i++) { String key = list.get(i); String old = map.get(key); if (old != null) { map.put(key, old + "," + (i + 1)); } else { map.put(key, "" + (i + 1)); } } Iterator<String> it = map.keySet().iterator(); int index = -1; while (it.hasNext()) { String key = it.next(); String value = map.get(key); if (value.indexOf(",") != -1) { System.out.println(key + " 重復(fù),行: " + value); indexArr = value.split(","); for (int i = 0; i < indexArr.length; i++) { index = Integer.parseInt(indexArr[i])-1; list.set(index, list.get(index)+(1+i)); } } } for (String val : list) { System.out.println("val = "+val); } System.out.println(".................."); }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
java、springboot?接口導(dǎo)出txt方式
這篇文章主要介紹了java、springboot?接口導(dǎo)出txt方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Java和C++通過new創(chuàng)建的對象有何區(qū)別?
Java和C++都是面向?qū)ο蟮木幊陶Z言,然而Java和C++在創(chuàng)建對象時(shí)卻存在不同的方式,由于方式的不同導(dǎo)致在內(nèi)存中管理的不同。這篇文章主要給大家介紹了關(guān)于Java和C++通過new創(chuàng)建對象區(qū)別的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-11-11HttpClient HttpRoutePlanner接口確定請求目標(biāo)路由
這篇文章主要為大家介紹了使用HttpClient HttpRoutePlanner接口確定請求目標(biāo)路由,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10spring?boot項(xiàng)目中如何使用nacos作為配置中心
這篇文章主要介紹了spring?boot項(xiàng)目中如何使用nacos作為配置中心問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12解決java項(xiàng)目jar打包后讀取文件失敗的問題
這篇文章主要介紹了解決java項(xiàng)目jar打包后讀取文件失敗的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06