Submission #7682535


Source Code Expand

import java.util.Scanner;

public class Main {
  public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    int N = scanner.nextInt();

    double[][] p = computeP(N);
    double[] exp = new double[N + 1];
    exp[1] = 0;
    for (int i = 2; i <= N; i++) {
      exp[i] = 1.d;
      for (int j = 1; j < i; j++) exp[i] += p[i][j] * exp[j];
      exp[i] /= 1 - p[i][i];
    }
    System.out.println(exp[N]);
  }

  private static double[][] computeP(int N) {
    double[][][] f = new double[N + 1][N + 1][N + 1];
    f[0][0][0] = 1.d;
    for (int i = 0; i <= N; i++) {
      for (int j = 0; j <= N; j++) {
        for (int k = 0; k <= N; k++) {
          if (i == 0 && k == 0 && j == 0) continue;
          f[i][j][k] = 0.d;
          if (i > 0) f[i][j][k] += f[i - 1][j][k];
          if (j > 0) f[i][j][k] += f[i][j - 1][k];
          if (k > 0) f[i][j][k] += f[i][j][k - 1];
          f[i][j][k] /= 3.d;
        }
      }
    }
    // n人がじゃんけんをして少数派がm人になる確率
    double[][] p = new double[N + 1][N + 1];
    for (int i = 0; i <= N; i++) {
      for (int j = 0; j <= N; j++) {
        for (int k = 0; k <= N; k++) {
          int n = i + j + k;
          if (n > N) continue;
          int m = (i == j && j == k) ? n : minNonZero(i, j, k);
          p[n][m] += f[i][j][k];
        }
      }
    }
    return p;
  }

  private static int minNonZero(int i, int j, int k) {
    if (i > j) return minNonZero(j, i, k);
    if (j > k) return minNonZero(i, k, j);
    if (i > 0) return i;
    if (j > 0) return j;
    return k;
  }
}

Submission Info

Submission Time
Task C - ゲーマーじゃんけん
User hkurokawa
Language Java8 (OpenJDK 1.8.0)
Score 100
Code Size 1655 Byte
Status AC
Exec Time 142 ms
Memory 30900 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 93 ms 20684 KB
input-003.txt AC 92 ms 19924 KB
input-004.txt AC 95 ms 20816 KB
input-005.txt AC 96 ms 22996 KB
input-006.txt AC 95 ms 19540 KB
input-007.txt AC 96 ms 19412 KB
input-008.txt AC 96 ms 21588 KB
input-009.txt AC 96 ms 23764 KB
input-010.txt AC 95 ms 19284 KB
input-011.txt AC 96 ms 21076 KB
input-012.txt AC 95 ms 18772 KB
input-013.txt AC 96 ms 21204 KB
input-014.txt AC 104 ms 21844 KB
input-015.txt AC 95 ms 19924 KB
input-016.txt AC 96 ms 18644 KB
input-017.txt AC 98 ms 21712 KB
input-018.txt AC 97 ms 19668 KB
input-019.txt AC 99 ms 18640 KB
input-020.txt AC 98 ms 19284 KB
input-021.txt AC 100 ms 19668 KB
input-022.txt AC 98 ms 21716 KB
input-023.txt AC 99 ms 20812 KB
input-024.txt AC 100 ms 19284 KB
input-025.txt AC 100 ms 19412 KB
input-026.txt AC 100 ms 18644 KB
input-027.txt AC 101 ms 23124 KB
input-028.txt AC 101 ms 20692 KB
input-029.txt AC 100 ms 19924 KB
input-030.txt AC 104 ms 21204 KB
input-031.txt AC 105 ms 19924 KB
input-032.txt AC 103 ms 21972 KB
input-033.txt AC 105 ms 20692 KB
input-034.txt AC 106 ms 18772 KB
input-035.txt AC 108 ms 20812 KB
input-036.txt AC 109 ms 19284 KB
input-037.txt AC 112 ms 17748 KB
input-038.txt AC 112 ms 20948 KB
input-039.txt AC 123 ms 23124 KB
input-040.txt AC 122 ms 18768 KB
input-041.txt AC 122 ms 21204 KB
input-042.txt AC 123 ms 20820 KB
input-043.txt AC 123 ms 19280 KB
input-044.txt AC 123 ms 18900 KB
input-045.txt AC 125 ms 20052 KB
input-046.txt AC 132 ms 24136 KB
input-047.txt AC 127 ms 22600 KB
input-048.txt AC 129 ms 24132 KB
input-049.txt AC 129 ms 22728 KB
input-050.txt AC 130 ms 21960 KB
input-051.txt AC 130 ms 24648 KB
input-052.txt AC 135 ms 22212 KB
input-053.txt AC 132 ms 24776 KB
input-054.txt AC 133 ms 23092 KB
input-055.txt AC 130 ms 24648 KB
input-056.txt AC 124 ms 22196 KB
input-057.txt AC 123 ms 21812 KB
input-058.txt AC 136 ms 24756 KB
input-059.txt AC 134 ms 21956 KB
input-060.txt AC 125 ms 22836 KB
input-061.txt AC 127 ms 21812 KB
input-062.txt AC 132 ms 22708 KB
input-063.txt AC 137 ms 22196 KB
input-064.txt AC 128 ms 24116 KB
input-065.txt AC 135 ms 22964 KB
input-066.txt AC 138 ms 23732 KB
input-067.txt AC 125 ms 22088 KB
input-068.txt AC 139 ms 22196 KB
input-069.txt AC 139 ms 22196 KB
input-070.txt AC 140 ms 22088 KB
input-071.txt AC 137 ms 26676 KB
input-072.txt AC 134 ms 25520 KB
input-073.txt AC 138 ms 23732 KB
input-074.txt AC 140 ms 24372 KB
input-075.txt AC 135 ms 26804 KB
input-076.txt AC 133 ms 25648 KB
input-077.txt AC 130 ms 26804 KB
input-078.txt AC 131 ms 26188 KB
input-079.txt AC 132 ms 24628 KB
input-080.txt AC 132 ms 24372 KB
input-081.txt AC 134 ms 24752 KB
input-082.txt AC 134 ms 26164 KB
input-083.txt AC 142 ms 28212 KB
input-084.txt AC 133 ms 27700 KB
input-085.txt AC 138 ms 27084 KB
input-086.txt AC 132 ms 28340 KB
input-087.txt AC 132 ms 30004 KB
input-088.txt AC 134 ms 26676 KB
input-089.txt AC 130 ms 26804 KB
input-090.txt AC 131 ms 25660 KB
input-091.txt AC 133 ms 28872 KB
input-092.txt AC 134 ms 27720 KB
input-093.txt AC 134 ms 25928 KB
input-094.txt AC 134 ms 28724 KB
input-095.txt AC 137 ms 28596 KB
input-096.txt AC 133 ms 30796 KB
input-097.txt AC 134 ms 28084 KB
input-098.txt AC 135 ms 30388 KB
input-099.txt AC 135 ms 27828 KB
input-100.txt AC 135 ms 30900 KB