Logo

Programming-Idioms

  • Perl
  • C++
  • Python

Idiom #246 Count distinct elements

Set c to the number of distinct elements in the list items.

c = len(set(items))
c = len({*items})
c = 0
for a, x in enumerate(items):
    if x not in items[a + 1:]:
        c = c + 1
c = []
for x in items:
    if x not in c:
        c.append(x)
c = len(c)
use List::Util qw(uniq);
my $c = scalar(uniq @items);
(def items [1 2 3 4 4 5 5 5])

(def c (count (set items)))

Converting a collection to a set removes any duplicate elements.

New implementation...
< >
programming-idioms.org