在使用Go語言的時候,碰到了需要對數(shù)組進行去重操作的問題。Java語言有Set集合這個數(shù)據(jù)結(jié)構(gòu),可以很方便的將數(shù)組轉(zhuǎn)為集合,但是Go語言沒有Set,如果僅僅是因為去重操作就手動實現(xiàn)一個Set太繁瑣了??梢愿鶕?jù)Go語言中的map的特性來簡單實現(xiàn)一下
華陰網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)于2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
這個是對字符串?dāng)?shù)組去重操作。可以根據(jù)需要的類型稍作修改即可。需要注意的是只支持可以作為map鍵的結(jié)構(gòu)進行去重!
今天給大家推薦是由Social Explorer團隊開源的gods框架,自稱"上帝",聽這個名字就很霸氣,正確的解釋是GoDS(Go Data Structures),是數(shù)據(jù)結(jié)構(gòu)與算法相關(guān)的框架。
全能戰(zhàn)士,該框架覆蓋了數(shù)據(jù)結(jié)構(gòu)與算法里,大部分容器、集合類的實現(xiàn), 比golang 的標(biāo)準(zhǔn)開發(fā)包提供更豐富的數(shù)據(jù)結(jié)構(gòu)。
在Go中實現(xiàn)各種數(shù)據(jù)結(jié)構(gòu)和算法。
吸取了其他算法庫數(shù)十年的知識和經(jīng)驗。
通過針對給定的一組問題使用最佳算法和數(shù)據(jù)結(jié)構(gòu)來避免消耗內(nèi)存,例如, 在TreeMap的情況下,紅黑樹避免在內(nèi)存中保留冗余排序的鍵數(shù)組。
結(jié)構(gòu)良好的庫,具有簡單的原子操作集,勝任復(fù)雜的數(shù)據(jù)操作。
保持庫向后兼容
可參考的例子非常多
可以方便集成到產(chǎn)品中.
沒有額外的導(dǎo)入.當(dāng)實現(xiàn)算法的時候,我們通常要在時間效率與內(nèi)存消耗之間權(quán)衡,我們選擇在內(nèi)存首先的情況下,不斷優(yōu)化得到最好的時間效率;線程安全不是重點,應(yīng)該在更高的應(yīng)用層上處理。
囊括了列表,棧,圖,樹等基本數(shù)據(jù)結(jié)構(gòu) ,集合實現(xiàn)了HashSet, TreeSet, LinkedHashSet,列表實現(xiàn)ArrayList, SinglyLinkedList, DoublyLinkedList,對棧實現(xiàn)LinkedListStack, ArrayStack,圖實現(xiàn)了HashMap, TreeMap, HashBidiMap, TreeBidiMap, LinkedHashMap,樹實現(xiàn)了RedBlackTree, AVLTree, BTree,BinaryHeap,都經(jīng)過性能測試的考驗,值得信賴。
對于Golang開發(fā)而言,gods對底層數(shù)據(jù)結(jié)構(gòu)做很好的封裝,Social Explorer團隊在數(shù)據(jù)處理領(lǐng)域,數(shù)據(jù)可視化領(lǐng)域有極具競爭力的產(chǎn)品,相信在數(shù)據(jù)處理領(lǐng)域有很深的積淀,才創(chuàng)造這么優(yōu)秀的框架,由于篇幅限制,相關(guān)圖片展示效果不好,感興趣的上官網(wǎng)去看看。
官網(wǎng):
GitHub
希望大家能從emirpasic/gods學(xué)到有價值的東西。
愿我們在Go 語言的學(xué)習(xí)之路上 從此結(jié)伴而行
直接將字符變量賦值給整型變量,即可實現(xiàn)字符到對應(yīng)ASCII碼的轉(zhuǎn)換。