SajwalAshish's blog

By SajwalAshish, history, 3 months ago, In English

Yes I know this might seem irrelevant for a Codeforces Blog but recently I came across something really interesting. A mathematical strategy that will always ensure a win in a gambling game! (Spoiler: Obviously there is a catch). What makes it relevant to post here is the perfect mathematics that goes behind it. Lets take a look at the maths behind a strategy that always guarantees a win.

The Martingale Strategy ensure a win in any game with close to 50 percent winning odds. Leaving out the part that it is a gambling strategy let us look at a scenario:

How it goes:

  • A bet of 1$ is made with 50 percent winning chances. If you win, you get 2$ but if you lose, you lose it all. If an infinite number of bets are made here, we will be in a situation of no profit and no loss.
  • A bet of 1$ is made with 49.5 percent winning chances. If you win, you get 2$ but if you lose, you lose it all. If a large number of bets are made here, we will be in a situation of a minor net loss. The tiny 0.5 percent is how any casino or gaming website ensures their profit.
  • Now the first case will never exist in the real world but the second might. This is where the martingale strategy comes into picture.

A noob's strategy:

  • If you win, increase the bet (because obviously he is lucky today)
  • If you lose, get scared and reset the bet

The Martingale Strategy:

  • It is the reverse of the strategy above
  • If you win, reset the bet
  • If you lose, double the bet

The Maths:

  • Lets say we start from 1$ and lose 5 bets in a row and win the 6th
  • Bet amounts are as follows : 1, 2, 4, 8, 16, 32 (The 6th bet's amount)
  • Total loss=1+2+4+8+16=31$, Total win=32$, Net profit= 32-31= 1$
  • You can try converting all the numbers to their binary equivalent. 31 is 11111 and 32 is 100000. What is interesting is that no matter where you start the bet from, after a complete losing streak, you regain the initial bet in profit.

How it ensures a win:

  • How convenient is it though? The probability of losing 5 matches in a row is 0.5^5 = 3.125 %. Now if you increase this to a 10 loss streak, a mere 0.09765 %. Now this is still more than my probability of becoming an expert on codeforces but I am certain none of you are as unlucky here.
  • You can almost be certain that a win is very close.
  • A person playing the martingale strategy gets happy after seeing losses.

Why it fails:

  • Now it all seemed too good right, and I am certain some of you would be ready to make their huge financial investments into gambling.
  • Hold your horses because to ensure a win always, you better have a billion dollars in the bank. Just like unbounded binary search, the bet space increases pretty fast here getting multiplied by powers of 2.
  • Lets say you are a billionaire. Do you still win? The clear answer is NO! Every casino or betting website has a minimum starting bet and a maximum bet. Once you put a cap on these two factors, you are screwed. Now you cannot increase your bet unboundedly which pretty much takes away the possibility of regaining all what has been lost.

While it is fun to try it out once, it becomes evident very soon that you can lose all your money in log(n) time complexity. The simple answer is "The House Always Wins". My suggestion is to never try it. No matter how rich you are, you can come to the road real quick with this optimized get ripped quick algorithm.

Full text and comments »

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

By SajwalAshish, history, 3 months ago, In English

Hi, my college has close to 200 teams for ICPC (all regions separated). I heard a rumor that 2 percent of teams qualify to the regionals. Does that mean that if there are 100 registrations in a region then not 1 but 2 teams will get selected from that college for a single region? Please clarify a little if anyone's college has had a similar situation in the past. I could not validate this information directly on the ICPC website.

Full text and comments »

  • Vote: I like it
  • -3
  • Vote: I do not like it

By SajwalAshish, history, 6 months ago, In English

I heard that codeforces has blocked its api during live contests to reduce server load. Because of this, the rating predictors are unable to function. Although it has been done for a good reason, the predictors not working until the end of the contest is pretty frustrating. Does anyone have an alternative or a fix to this issue?

Full text and comments »

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

By SajwalAshish, history, 8 months ago, In English

A few hours ago I tried submitting a problem and noticed that it just wont exit the queue and the testcases never ran. Confident that it would work, I started solving another problem. When i submitted it i noticed the previous solution was still stuck in the queue. I gave it time to wait and went for a 2 hour nap. Turns out it is still stuck in the queue. This triggers my anxiety for today's educational round. Requesting the CF team to look into this issue and fix it ASAP.

PS: The issue has been resolved and the questions are being judged fine now.

Full text and comments »

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