Hatena::Grouptopcoder

cafelier@SRM

cafelier のSRM参加記録です。コンテスト中に考えてたことを執拗に全部書き残すとどうなるだろうかという試み本番中にこういうコードが書きたかったなあ、という後で書いた反省コードを書き残す試み

スパムが来たのでしばらくコメント欄をはてなユーザ限定にしています、すみません、

 | 

2010-01-15

SRM458 250

| 01:41 | はてなブックマーク -  SRM458 250 - cafelier@SRM

考えたら、2^N 通りの向きを全生成なんてする必要ないですよね。各ペアについて、向きが衝突する向きになる確率は1/4なんだから、「距離2*T以内にあるペアの数 / 4」が答えだ。

class BouncingBalls { public:
   double expectedBounces(vector <int> x, int T) 
   {
      int crashPair = 0;
      for(int i=0; i<x.size(); ++i)
         for(int j=i+1; j<x.size(); ++j)
            if( abs(x[i]-x[j]) <= 2*T )
               crashPair ++;
      return crashPair / 4.0;
   }
};
トラックバック - https://topcoder-g-hatena-ne-jp.jag-icpc.org/cafelier/20100115
 | 

presented by cafelier/k.inaba under CC0