Only by contending with challenges that seem to be beyond your strength to handle at the moment you can grow more surely toward the stars.

Hi! Welcome to my first post in English :).

Today was held the first World Finals Warmup 2012 and I was reading(don't solving) the problems and I found a very interesting fact in problem E, Good Words, and well that is what I'll write in this post.

Suppose a word consisting of only 0 and 1 is called good if there is no adjacent one in the word. We are asked to find good words of length n.

At first the problem may appear difficult but actually it can be solved with a little insight: initially we have *n* spaces, the first good word is the one formed by only '0's, ok?, if you decide the first digit to be '0' then you can fill up the remaining *n-1* as we like respecting the condition of no two adjacent '1's, now if you decide the first digit to be '1' then the second digit must be '0' and now we face with the problem of the first case but with *n-2*. If we are able to find all possible good words for *n = 1* and *n = 2* we'll be able to get the answer for any *n* greater that two with W_{n} = W_{n-1} + W_{n-2}.

n | Good words |
---|---|

1 | 0, 1 |

2 | 00, 01, 10 |

3 | 000, 001, 010, 100, 101000, 001, 010, 100, 101 |

The first thing that came to my mind was use dynamic programming but all indicates that in many occasions is very important don't rush out with the first idea since is very likely isn't the best. Well, this is all for this post, I will see you in next post!The first thing that came to my mind was use dynamic programming but all indicates that in many occasions is very important don't rush out with the first idea since is very likely isn't the best. Well, this is all for this post, I will see you in next post!