Ayalla's blog

By Ayalla, history, 4 years ago, In English

Hello codeforces!

This is my first blog written here, so I apologize if this blog is not good. Any suggestion for improvement will be welcome!

Example Problem:

You are given two integers ($$$0$$$ <= $$$l$$$ <= $$$r$$$ <= $$$10^9$$$) and you have to count the number of pairs ($$$i$$$, $$$j$$$) which $$$i$$$ & $$$j$$$ = 0 with $$$l$$$ <= $$$i$$$, $$$j$$$ <= $$$r$$$. Which "&" denotes the Bitiwse AND.

What is Digit DP?

Problems like "count the number of pairs of numbers that satisfy some condition" or "count the number of numbers that satisfy some condition" can usually be done with digit DP, depending on the constants.

You can read more about digit DP at these links:

Link 1

Link 2

In some of these problems, the DP transitions are like: "I am in a position (digit) of the number that I am building and I have some options of digits that I can put in this position". However, in this problem, we cannot build a DP of this type.

How to solve this problem?

In this case, we will approach this DP in a similar way but, instead of thinking of the transition as "put this digit or not?" we will think in this transition as "set this bit or not?". Note that now with this idea, this problem becomes much easier, because in general we will have 3 options for the transition of dp in this problem.

1 — Set the current bit in $$$i$$$.

2 — Set the current bit in $$$j$$$.

3 — Set the current bit in none of the numbers.

Note that we cannot set a bit in both numbers, because their bitwise AND must result in 0.

Note that we must also be careful to know if both numbers are inside the range $$$[l, r]$$$. For that, we will decrase the value of $$$l$$$ and increase $$$r$$$ and use some dimensions of the DP to know if both numbers are bigger than $$$l$$$ and lower than $$$r$$$.

In the end, the DP will look like this:

DP[current_bit][i is bigger than l][i is lower than r][j is bigger than l][j is lower than r]

Code

Problems:

Daniel and Spring Cleaning

Fun with Stones

Coincidence

Little Girl and Maximum XOR

If you know about more problems of this type and if you can share with us, it would be awesome :)

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

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

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

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

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

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

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

»
4 years ago, # |
Rev. 4   Vote: I like it 0 Vote: I do not like it

This may be easier to implement:

The result is $$$a-2b+c$$$, where

  • $$$a = $$$ # of pairs with $$$i$$$ in $$$[0, r]$$$ and $$$j$$$ in $$$[0, r]$$$
  • $$$b = $$$ # of pairs with $$$i$$$ in $$$[0, l-1]$$$ and $$$j$$$ in $$$[0, r]$$$
  • $$$c = $$$ # of pairs with $$$i$$$ in $$$[0, l-1]$$$ and $$$j$$$ in $$$[0, l-1]$$$

Then you need only a 3D DP instead of a 5D DP.

  • »
    »
    4 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    This idea is great

    Thanks for writing!

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

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