Submission #323742


Source Code Expand

n = gets.to_i

$c = Array.new(101)
(0..100).each do |i|
	$c[i] = Array.new(101)
	$c[i][0] = $c[i][i] = 1
	(1..(i-1)).each do |j|
		$c[i][j] = $c[i-1][j-1] + $c[i-1][j]
	end
end


$memo = Array.new(101, -1)
def dfs(n)
	return 0.0 if n == 1
	return 1.5 if n == 2
	return $memo[n] if $memo[n] >= 0
	
	p1 = 1.0 / (3 ** (n-1))
	if n % 3 == 0
		p1 += 1.0 * ($c[n][n/3] * $c[n*2/3][n/3]) / (3 ** n)
	end
	
	ret = 0.0
	p2 = 0
	(1..n).each { |v| 
		(v..n).each { |u|
			l = n-v-u
			next if l < 0
			if l == 0
				l = 1000
			end
			next unless (v <= u and u <= l)
			next if (v == u and u == l)
			
			k = (v == u or u == l) ? 3.0 : 6.0
			p2 += k * ($c[n][v] * $c[n-v][u]) / (3 ** n) 
			ret += k * ($c[n][v] * $c[n-v][u]) / (3 ** n) * (1.0 + dfs(v))
		}
	}
	
	$memo[n] = (ret + p1) / (1.0 - p1)
	$memo[n]
end

p dfs(n)

Submission Info

Submission Time
Task C - ゲーマーじゃんけん
User hamadu
Language Ruby (1.9.3)
Score 100
Code Size 859 Byte
Status AC
Exec Time 91 ms
Memory 4460 KB

Judge Result

Set Name All
Score / Max Score 100 / 100
Status
AC × 99
Set Name Test Cases
All input-002.txt, input-003.txt, input-004.txt, input-005.txt, input-006.txt, input-007.txt, input-008.txt, input-009.txt, input-010.txt, input-011.txt, input-012.txt, input-013.txt, input-014.txt, input-015.txt, input-016.txt, input-017.txt, input-018.txt, input-019.txt, input-020.txt, input-021.txt, input-022.txt, input-023.txt, input-024.txt, input-025.txt, input-026.txt, input-027.txt, input-028.txt, input-029.txt, input-030.txt, input-031.txt, input-032.txt, input-033.txt, input-034.txt, input-035.txt, input-036.txt, input-037.txt, input-038.txt, input-039.txt, input-040.txt, input-041.txt, input-042.txt, input-043.txt, input-044.txt, input-045.txt, input-046.txt, input-047.txt, input-048.txt, input-049.txt, input-050.txt, input-051.txt, input-052.txt, input-053.txt, input-054.txt, input-055.txt, input-056.txt, input-057.txt, input-058.txt, input-059.txt, input-060.txt, input-061.txt, input-062.txt, input-063.txt, input-064.txt, input-065.txt, input-066.txt, input-067.txt, input-068.txt, input-069.txt, input-070.txt, input-071.txt, input-072.txt, input-073.txt, input-074.txt, input-075.txt, input-076.txt, input-077.txt, input-078.txt, input-079.txt, input-080.txt, input-081.txt, input-082.txt, input-083.txt, input-084.txt, input-085.txt, input-086.txt, input-087.txt, input-088.txt, input-089.txt, input-090.txt, input-091.txt, input-092.txt, input-093.txt, input-094.txt, input-095.txt, input-096.txt, input-097.txt, input-098.txt, input-099.txt, input-100.txt
Case Name Status Exec Time Memory
input-002.txt AC 68 ms 4336 KB
input-003.txt AC 71 ms 4320 KB
input-004.txt AC 67 ms 4332 KB
input-005.txt AC 65 ms 4332 KB
input-006.txt AC 67 ms 4336 KB
input-007.txt AC 65 ms 4336 KB
input-008.txt AC 67 ms 4336 KB
input-009.txt AC 65 ms 4332 KB
input-010.txt AC 67 ms 4340 KB
input-011.txt AC 67 ms 4320 KB
input-012.txt AC 66 ms 4328 KB
input-013.txt AC 67 ms 4332 KB
input-014.txt AC 65 ms 4312 KB
input-015.txt AC 73 ms 4336 KB
input-016.txt AC 67 ms 4328 KB
input-017.txt AC 65 ms 4332 KB
input-018.txt AC 65 ms 4336 KB
input-019.txt AC 66 ms 4332 KB
input-020.txt AC 66 ms 4336 KB
input-021.txt AC 66 ms 4328 KB
input-022.txt AC 67 ms 4344 KB
input-023.txt AC 66 ms 4332 KB
input-024.txt AC 65 ms 4320 KB
input-025.txt AC 68 ms 4336 KB
input-026.txt AC 67 ms 4336 KB
input-027.txt AC 66 ms 4336 KB
input-028.txt AC 66 ms 4372 KB
input-029.txt AC 65 ms 4332 KB
input-030.txt AC 65 ms 4336 KB
input-031.txt AC 67 ms 4328 KB
input-032.txt AC 65 ms 4336 KB
input-033.txt AC 65 ms 4332 KB
input-034.txt AC 67 ms 4332 KB
input-035.txt AC 66 ms 4332 KB
input-036.txt AC 69 ms 4332 KB
input-037.txt AC 68 ms 4308 KB
input-038.txt AC 69 ms 4396 KB
input-039.txt AC 69 ms 4340 KB
input-040.txt AC 73 ms 4336 KB
input-041.txt AC 70 ms 4304 KB
input-042.txt AC 68 ms 4336 KB
input-043.txt AC 70 ms 4388 KB
input-044.txt AC 68 ms 4328 KB
input-045.txt AC 68 ms 4336 KB
input-046.txt AC 67 ms 4336 KB
input-047.txt AC 69 ms 4336 KB
input-048.txt AC 69 ms 4328 KB
input-049.txt AC 71 ms 4316 KB
input-050.txt AC 69 ms 4332 KB
input-051.txt AC 69 ms 4336 KB
input-052.txt AC 67 ms 4336 KB
input-053.txt AC 67 ms 4328 KB
input-054.txt AC 69 ms 4296 KB
input-055.txt AC 70 ms 4332 KB
input-056.txt AC 69 ms 4332 KB
input-057.txt AC 71 ms 4340 KB
input-058.txt AC 69 ms 4332 KB
input-059.txt AC 69 ms 4324 KB
input-060.txt AC 71 ms 4336 KB
input-061.txt AC 71 ms 4336 KB
input-062.txt AC 70 ms 4336 KB
input-063.txt AC 73 ms 4392 KB
input-064.txt AC 70 ms 4312 KB
input-065.txt AC 72 ms 4336 KB
input-066.txt AC 70 ms 4336 KB
input-067.txt AC 71 ms 4332 KB
input-068.txt AC 72 ms 4316 KB
input-069.txt AC 72 ms 4332 KB
input-070.txt AC 72 ms 4304 KB
input-071.txt AC 71 ms 4356 KB
input-072.txt AC 72 ms 4328 KB
input-073.txt AC 71 ms 4380 KB
input-074.txt AC 74 ms 4336 KB
input-075.txt AC 74 ms 4332 KB
input-076.txt AC 72 ms 4328 KB
input-077.txt AC 75 ms 4332 KB
input-078.txt AC 76 ms 4460 KB
input-079.txt AC 73 ms 4332 KB
input-080.txt AC 78 ms 4332 KB
input-081.txt AC 75 ms 4336 KB
input-082.txt AC 77 ms 4336 KB
input-083.txt AC 78 ms 4332 KB
input-084.txt AC 77 ms 4332 KB
input-085.txt AC 77 ms 4392 KB
input-086.txt AC 77 ms 4336 KB
input-087.txt AC 80 ms 4324 KB
input-088.txt AC 78 ms 4336 KB
input-089.txt AC 78 ms 4336 KB
input-090.txt AC 82 ms 4332 KB
input-091.txt AC 79 ms 4308 KB
input-092.txt AC 82 ms 4336 KB
input-093.txt AC 85 ms 4332 KB
input-094.txt AC 82 ms 4328 KB
input-095.txt AC 83 ms 4336 KB
input-096.txt AC 82 ms 4312 KB
input-097.txt AC 83 ms 4336 KB
input-098.txt AC 81 ms 4336 KB
input-099.txt AC 86 ms 4332 KB
input-100.txt AC 91 ms 4336 KB