Golang : How to count duplicate items in slice/array?
Problem :
You need to count the number of duplicate items in a slice or array.
Solution :
Pseudo-code : Create a map and insert one item from the slice/array with a for loop. Before inserting a new item check if a similar item already exist in the map. If yes, increase the counter value associated with the particular item and if no, assign a new counter with the value of 1 for the new item(in the map).
Here you go :
package main
import (
"fmt"
)
func printslice(slice []string) {
fmt.Println("slice = ", slice)
}
func dup_count(list []string) map[string]int {
duplicate_frequency := make(map[string]int)
for _, item := range list {
// check if the item/element exist in the duplicate_frequency map
_, exist := duplicate_frequency[item]
if exist {
duplicate_frequency[item] += 1 // increase counter by 1 if already in the map
} else {
duplicate_frequency[item] = 1 // else start counting from 1
}
}
return duplicate_frequency
}
func main() {
duplicate := []string{"Hello", "World", "GoodBye", "World", "We", "Love", "Love", "You"}
printslice(duplicate)
dup_map := dup_count(duplicate)
//fmt.Println(dup_map)
for k, v := range dup_map {
fmt.Printf("Item : %s , Count : %d\n", k, v)
}
}
Sample output :
slice = [Hello World GoodBye World We Love Love You]
Item : You , Count : 1
Item : Hello , Count : 1
Item : World , Count : 2
Item : GoodBye , Count : 1
Item : We , Count : 1
Item : Love , Count : 2
See also : Golang : Delete duplicate items from a slice/array
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+8.2k Golang : Multiplexer with net/http and map
+18.1k Golang : Get all upper case or lower case characters from string example
+21.2k Golang : Sort and reverse sort a slice of strings
+9.9k Golang : Format strings to SEO friendly URL example
+16.5k CodeIgniter/PHP : Create directory if does not exist example
+15.2k Golang : How do I get the local IP (non-loopback) address ?
+7.7k Golang : Dealing with struct's private part
+11.7k Golang : Fuzzy string search or approximate string matching example
+5.4k Golang : Generate Interleaved 2 inch by 5 inch barcode
+4.1k Detect if Google Analytics and Developer Media are loaded properly or not
+31.7k Golang : Example for ECDSA(Elliptic Curve Digital Signature Algorithm) package functions
+5.3k Responsive Google Adsense