Java conta ocorrência de cada item em um array

Existe algum método para contar a ocorrência de cada item em uma matriz?

Vamos dizer que eu tenho:

String[] array = {"name1","name2","name3","name4", "name5"}; 

Aqui a saída será:

 name1 1 name2 1 name3 1 name4 1 name5 1 

e se eu tiver:

 String[] array = {"name1","name1","name2","name2", "name2"}; 

A saída seria:

 name1 2 name2 3 

A saída aqui é apenas para demonstrar o resultado esperado.

Você pode usar um MultiSet do Google Collections / Guava ou um Bag do Apache Commons.

Se você tiver uma coleção em vez de uma matriz, você pode usar addAll() para adicionar todo o conteúdo à estrutura de dados acima e aplicar o método count() a cada valor. Um SortedMultiSet ou SortedBag daria os itens em uma ordem definida.

O Google Collections na verdade tem maneiras muito convenientes de ir de arrays para um SortedMultiset .

 List asList = Arrays.asList(array); Set mySet = new HashSet(asList); for(String s: mySet){ System.out.println(s + " " +Collections.frequency(asList,s)); } 

Com o java-8 , você pode fazer assim:

 String[] array = {"name1","name2","name3","name4", "name5", "name2"}; Arrays.stream(array) .collect(Collectors.groupingBy(s -> s)) .forEach((k, v) -> System.out.println(k+" "+v.size())); 

Saída:

 name5 1 name4 1 name3 1 name2 2 name1 1 

O que isso faz é:

  • Crie um Stream na matriz original
  • Agrupe cada elemento por identidade, resultando em um Map>
  • Para cada par de valores-chave, imprima a chave e o tamanho da lista

Se você deseja obter um Map que contenha o número de ocorrências para cada palavra, isso pode ser feito fazendo:

 Map map = Arrays.stream(array) .collect(Collectors.groupingBy(s -> s, Collectors.counting())); 

Para mais informações:

  • Stream
  • Collectors

Espero que ajude! 🙂

Eu usaria um hashtable com na chave leva o elemento da matriz (aqui string) e no valor de um inteiro.

então percorra a lista fazendo algo assim:

 for(String s:array){ if(hash.containsKey(s)){ Integer i = hash.get(s); i++; }else{ hash.put(s, new Interger(1)); } 

Eu escrevi uma solução para isso para me praticar. Não parece tão incrível quanto as outras respostas postadas, mas vou postar de qualquer maneira, e então aprender como fazer isso usando os outros methods também. Apreciar:

 public static Integer[] countItems(String[] arr) { List itemCount = new ArrayList(); Integer counter = 0; String lastItem = arr[0]; for(int i = 0; i < arr.length; i++) { if(arr[i].equals(lastItem)) { counter++; } else { itemCount.add(counter); counter = 1; } lastItem = arr[i]; } itemCount.add(counter); return itemCount.toArray(new Integer[itemCount.size()]); } public static void main(String[] args) { String[] array = {"name1","name1","name2","name2", "name2", "name3", "name1","name1","name2","name2", "name2", "name3"}; Arrays.sort(array); Integer[] cArr = countItems(array); int num = 0; for(int i = 0; i < cArr.length; i++) { num += cArr[i]-1; System.out.println(array[num] + ": " + cArr[i].toString()); } } 

Usando o HashMap é andar no parque.

 main(){ String[] array ={"a","ab","a","abc","abc","a","ab","ab","a"}; Map hm = new HashMap(); for(String x:array){ if(!hm.containsKey(x)){ hm.put(x,1); }else{ hm.put(x, hm.get(x)+1); } } System.out.println(hm); } 

Aqui está a minha solução – O método leva uma matriz de inteiros (assumindo o intervalo entre 0 a 100) como input e retorna o número de ocorrências de cada elemento.

Digamos que a input seja [21,34,43,21,21,21,45,65,65,76,76,76] . Assim, a saída seria em um mapa e é: {34=1, 21=4, 65=2, 76=3, 43=1, 45=1}

 public Map countOccurrence(int[] numbersToProcess) { int[] possibleNumbers = new int[100]; Map result = new HashMap(); for (int i = 0; i < numbersToProcess.length; ++i) { possibleNumbers[numbersToProcess[i]] = possibleNumbers[numbersToProcess[i]] + 1; result.put(numbersToProcess[i], possibleNumbers[numbersToProcess[i]]); } return result; } 

Você pode fazer isso usando Arrays.sort e Recursion. O mesmo vinho, mas em uma garrafa diferente ….

 import java.util.Arrays; public class ArrayTest { public static int mainCount=0; public static void main(String[] args) { String prevItem = ""; String[] array = {"name1","name1","name2","name2", "name2"}; Arrays.sort(array); for(String item:array){ if(! prevItem.equals(item)){ mainCount = 0; countArray(array, 0, item); prevItem = item; } } } private static void countArray(String[] arr, int currentPos, String item) { if(currentPos == arr.length){ System.out.println(item + " " + mainCount); return; } else{ if(arr[currentPos].toString().equals(item)){ mainCount += 1; } countArray(arr, currentPos+1, item); } } } 

Isso pode ser feito de uma forma muito simples usando collections, por favor, encontrar o código abaixo

 String[] array = {"name1","name1","name2","name2", "name2"}; List sampleList=(List) Arrays.asList(array); for(String inpt:array){ int frequency=Collections.frequency(sampleList,inpt); System.out.println(inpt+" "+frequency); } 

Aqui a saída será como name1 2 name1 2 name2 3 name2 3 name2 3

Para evitar a impressão de chaves redundantes, use o HashMap e obtenha a saída desejada

Você pode usar o Mapa de hash como indicado no exemplo abaixo:

 import java.util.HashMap; import java.util.Set; /** * * @author Abdul Rab Khan * */ public class CounterExample { public static void main(String[] args) { String[] array = { "name1", "name1", "name2", "name2", "name2" }; countStringOccurences(array); } /** * This method process the string array to find the number of occurrences of * each string element * * @param strArray * array containing string elements */ private static void countStringOccurences(String[] strArray) { HashMap countMap = new HashMap(); for (String string : strArray) { if (!countMap.containsKey(string)) { countMap.put(string, 1); } else { Integer count = countMap.get(string); count = count + 1; countMap.put(string, count); } } printCount(countMap); } /** * This method will print the occurrence of each element * * @param countMap * map containg string as a key, and its count as the value */ private static void printCount(HashMap countMap) { Set keySet = countMap.keySet(); for (String string : keySet) { System.out.println(string + " : " + countMap.get(string)); } } } 

Existem vários methods que podem ajudar, mas este é um usando o loop.

 import java.util.Arrays; public class one_dimensional_for { private static void count(int[] arr) { Arrays.sort(arr); int sum = 0, counter = 0; for (int i = 0; i < arr.length; i++) { if (arr[0] == arr[arr.length - 1]) { System.out.println(arr[0] + ": " + counter + " times"); break; } else { if (i == (arr.length - 1)) { sum += arr[arr.length - 1]; counter++; System.out.println((sum / counter) + " : " + counter + " times"); break; } else { if (arr[i] == arr[i + 1]) { sum += arr[i]; counter++; } else if (arr[i] != arr[i + 1]) { sum += arr[i]; counter++; System.out.println((sum / counter) + " : " + counter + " times"); sum = 0; counter = 0; } } } } } public static void main(String[] args) { int nums[] = { 1, 1, 1, 1, 2, 2, 2, 3, 3, 4, 5, 5, 5, 5, 6 }; count(nums); } } 

Este é um script simples que eu usei no Python, mas pode ser facilmente adaptado. Nada extravagante embora.

 def occurance(arr): results = [] for n in arr: data = {} data["point"] = n data["count"] = 0 for i in range(0, len(arr)): if n == arr[i]: data["count"] += 1 results.append(data) return results 

você pode encontrar usando HashMap com técnica simples

 public class HashMapExample { public static void main(String[] args) { stringArray(); } public static void stringArray() { String[] a = {"name1","name2","name3","name4", "name5"}; Map hm = new HashMap(); for(int i=0;i 

// Uma resposta sem o uso de Hashset ou mapa ou Arraylist

 public class Count { static String names[] = {"name1","name1","name2","name2", "name2"}; public static void main(String args[]) { printCount(names); } public static void printCount(String[] names){ java.util.Arrays.sort(names); int n = names.length, c; for(int i=0;i= max){ max = result[i]; index = i; } } } } 

Você pode usar o HashMap, onde Key é sua string e valor – contagem.

 import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; import java.util.List; public class MultiString { public HashMap countIntem( String[] array ) { Arrays.sort(array); HashMap map = new HashMap(); Integer count = 0; String first = array[0]; for( int counter = 0; counter < array.length; counter++ ) { if(first.hashCode() == array[counter].hashCode()) { count = count + 1; } else { map.put(first, count); count = 1; } first = array[counter]; map.put(first, count); } return map; } /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub String[] array = { "name1", "name1", "name2", "name2", "name2", "name3", "name1", "name1", "name2", "name2", "name2", "name3" }; HashMap countMap = new MultiString().countIntem(array); System.out.println(countMap); } } Gives you O(n) complexity.