Hatena::Grouptopcoder

isa@procon このページをアンテナに追加 RSSフィード

2011-11-14

AOJ 1020 Cleaning Robot

| 22:50

問題文

http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=1020

方針

dp[second][pos]で

i+1秒後に次の移動先next_posに移動できるなら

dp[i+1][next_pos] += dp[i][pos] * 0.25;

そうでなければ

dp[i+1][pos] += dp[i][pos] * 0.25;

とすればよい。

以下ソース

#include <iostream>
#include <cstdio>
#include <algorithm>

#define MAX_SEC 15
#define MAX_STATE 1 << 9

#define FILL(ptr, value) FILL_((ptr), sizeof(ptr)/sizeof(value), (value))
template <typename T>
void FILL_(void * ptr, size_t size, T value){
  std::fill((T*)ptr, (T*)ptr+size, value);
}

using namespace std;

double dp[MAX_SEC+1][9];
int dx[4] = {1,0,-1,0};
int dy[4] = {0,1,0,-1};
int dir[4] = {1,3,-1,-3};

int main(void){
  int n;
  while(cin >> n && n){
    FILL(dp,0);
    char tmp;
    int s,t,b,x,y;

    cin >> tmp; s = (int)(tmp - 'A');
    cin >> tmp; t = (int)(tmp - 'A');
    cin >> tmp; b = (int)(tmp - 'A');

    dp[0][s] = 1;
    for(int i=0;i<n;i++){
      for(int j=0;j<9;j++){
	if(dp[i][j] == 0) continue;
	x = j%3;
	y = j/3;
	for(int k=0;k<4;k++){
	  if(0 <= x+dx[k] && x+dx[k] < 3 &&
	     0 <= y+dy[k] && y+dy[k] < 3 &&
	     j+dir[k] != b){
	    dp[i+1][j+dir[k]] += dp[i][j] * 0.25;
	  }else{
	    dp[i+1][j] += dp[i][j] * 0.25;
	  }
	}
      }
    }
    printf("%.8lf\n", dp[n][t]);
  }
}

SRM 523 Div.1

| 21:46

x-- (+0/-0) 0pts 467th

Ratingは1371->1321 (-50)

250

初め upperBound <= 10^5 かと勘違いしてなにこれ?と思うものの読み進める

等差数列は計算で、等比数列の方は計算して等差数列とかぶってれば増やさない、

という方針でやったものの、多くの人と同じく

upperBound < a

を忘れててChallenge Suceeded.

500

DPむりげー。強くなりたい。

まとめ

次回はがんばります。