A是一个数组:确定A中是否存在两个相同次数的整数

时间:2018-02-20 16:56:47

标签: arrays algorithm pseudocode find-occurrences

例如:A = [1,2,2,3,4,5,5] - > true; A = [1,2,2,3,3,3,4,4,4,4] - GT;假

proc(A){
list = newList()
for (i=1 to length[A]) {
   occ = 0
   n = a[i]
   for (j = 1 to length[A]) {
       if(a[j] == n)
            occ++
    } 
    list.append(occ)
}

但是没有用,因为在列表中将重复元素。我想过使用类似于countingSort的算法,但我不知道支持向量的长度。

有任何帮助吗?在伪代码中会很好。 谢谢。

1 个答案:

答案 0 :(得分:0)

通过使用地图和集等数据结构,可以非常轻松地完成此任务。

Algorithm:-
-> Loop through the array and store it in hashmap with key as the value of the array element and value as the count of it's occurrence.
-> Create an empty set
-> Loop through the map and keep storing the value of every key in the set and if somewhere in between looping u come across any value that's already there in the set, then return true else if u reach the end of map, then return false.

现在让我们看看Pseudocode。

Pseudocode:-
-> we have input array as arr and length n
-> we create an empty map - m[int, int]
-> for (i -> 0 to n-1)
   {
      m[arr[i]]++;
   }
-> This in the end will give us our map which we want with key as the array element and value as it's count
-> create a set - s
-> iterate over map m as key -> value
   {
      if (value present in s) {
         return true
      }
      s.insert(value)
    }
-> If we reach here then it means we never came across any pair of elements whose occurrence is same, so return false.

希望这有帮助!