snacache's blog

By snacache, history, 8 years ago, In English

Hello Codeforces Community!

I have been solving some interesting bitmasks problems. In some problems, we have to generate all possible subsets from a set. Obviously, if our set is a bitmask with all its bits on, we can iterate from 0 to 2n - 1

However, if we need to generate all the subsets from another subset (subset-ception), we can do it with the following procedure:

for(subset = set; subset > 0; subset = (subset - 1)&set)

(The code above ignores the empty subset)

Generate all the subsets from all possible subsets has O(3n) complexity. Now, I can intuitively confirm this, because we can represent our subsets as a string with 3 possible values: while 1 and 0 at position i means that the object i is in our subset or not respectively, 2 means that the object i is not present in the set at all.

However, mathematically:

Amazing! I cannot find a way to prove this though. Do you know how to prove this interesting property?

Update: Solved, thanks! It was very simple :(

  • Vote: I like it
  • +47
  • Vote: I do not like it

»
8 years ago, # |
  Vote: I like it 0 Vote: I do not like it

Auto comment: topic has been updated by snacache (previous revision, new revision, compare).

»
8 years ago, # |
  Vote: I like it +20 Vote: I do not like it

Why minus? he's asking a reasonable question (lol memes)
Anyway consider every i from 0 to 3 ^ n — 1 and its ternary form, a0 a2 ... an-1, for every i if ai is 2 it's in both set and subset, if it's one it's only in set, else it's in neither of them

»
8 years ago, # |
  Vote: I like it +91 Vote: I do not like it

(1 + 2)n

»
8 years ago, # |
  Vote: I like it +41 Vote: I do not like it
Now, I can intuitively confirm this, because we can represent our subsets as a string with 3 possible values: while 1 and 0 at position i means that the object i is in our subset or not respectively, 2 means that the object i is not present in the set at all.

That's the proof.

»
8 years ago, # |
  Vote: I like it +19 Vote: I do not like it

This follows directly from the binomial theorem.

»
8 years ago, # |
  Vote: I like it 0 Vote: I do not like it

Auto comment: topic has been updated by snacache (previous revision, new revision, compare).

»
8 years ago, # |
  Vote: I like it +4 Vote: I do not like it

Found a problem using this idea link