Submission #7461351


Source Code Expand

#define _USE_MATH_DEFINES
#include <bits/stdc++.h>
using namespace std;

//template
#define rep(i,a,b) for(int i=(a);i<(b);i++)
#define rrep(i,a,b) for(int i=(a);i>(b);i--)
#define ALL(v) (v).begin(),(v).end()
typedef long long int ll; typedef pair<ll, ll> P;
template<class T> inline bool chmax(T& a, T b) { if (a < b) { a = b; return 1; } return 0; }
template<class T> inline bool chmin(T& a, T b) { if (a > b) { a = b; return 1; } return 0; }
template<typename A,size_t N,typename T>void Fill(A(&array)[N],const T &val){fill((T*)array, (T*)(array+N), val);}
const int inf = INT_MAX / 2; const ll INF = LLONG_MAX / 2;
//template end

double C[110][110]={},pw[110],dp[110]={};
double f(int r,int s,int p){
    return C[r+s+p][r]*C[s+p][s]*pw[r+s+p];
}

int main(){
    int n; scanf("%d",&n);
    rep(i,0,110){
        C[i][0]=C[i][i]=1;
        rep(j,1,i)C[i][j]=C[i-1][j]+C[i-1][j-1];
    }
    pw[0]=1.0;
    rep(i,1,110)pw[i]=pw[i-1]*1.0/3;
    rep(m,2,n+1){
        double sum[110]={},lop=0;
        rep(r,0,m+1)rep(s,0,m+1-r){
            int p=m-r-s;
            double pp=f(r,s,p);
            int mi=inf,cnt=0,a[]={r,s,p},idx=-1;
            rep(i,0,3)if(a[i]){
                cnt++; chmin(mi,a[i]);
            }
            if(cnt==1){
                lop+=pp; continue;
            } cnt=0;
            rep(i,0,3){
                if(a[i]==mi)cnt++;
                else idx=i;
            }
            if(cnt==1)sum[mi]+=pp;
            else if(cnt==3)lop+=pp;
            else sum[a[(idx+1)%3]]+=pp;
        }
        rep(i,2,m)dp[m]+=dp[i]*sum[i];
        dp[m]=(dp[m]+lop+1.0-lop)/(1.0-lop);
    }
    printf("%.12f\n",dp[n]);
    return 0;
}

Submission Info

Submission Time
Task C - ゲーマーじゃんけん
User TKO
Language C++14 (GCC 5.4.1)
Score 100
Code Size 1713 Byte
Status AC
Exec Time 3 ms
Memory 384 KB

Compile Error

./Main.cpp: In function ‘int main()’:
./Main.cpp:22:26: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result]
     int n; scanf("%d",&n);
                          ^

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 1 ms 384 KB
input-003.txt AC 1 ms 384 KB
input-004.txt AC 1 ms 384 KB
input-005.txt AC 1 ms 384 KB
input-006.txt AC 1 ms 384 KB
input-007.txt AC 1 ms 384 KB
input-008.txt AC 1 ms 384 KB
input-009.txt AC 1 ms 384 KB
input-010.txt AC 1 ms 384 KB
input-011.txt AC 1 ms 384 KB
input-012.txt AC 1 ms 384 KB
input-013.txt AC 1 ms 384 KB
input-014.txt AC 1 ms 384 KB
input-015.txt AC 1 ms 384 KB
input-016.txt AC 1 ms 384 KB
input-017.txt AC 1 ms 384 KB
input-018.txt AC 1 ms 384 KB
input-019.txt AC 1 ms 384 KB
input-020.txt AC 1 ms 384 KB
input-021.txt AC 1 ms 384 KB
input-022.txt AC 1 ms 384 KB
input-023.txt AC 1 ms 384 KB
input-024.txt AC 1 ms 384 KB
input-025.txt AC 1 ms 384 KB
input-026.txt AC 1 ms 384 KB
input-027.txt AC 1 ms 384 KB
input-028.txt AC 1 ms 384 KB
input-029.txt AC 1 ms 384 KB
input-030.txt AC 1 ms 384 KB
input-031.txt AC 1 ms 384 KB
input-032.txt AC 1 ms 384 KB
input-033.txt AC 1 ms 384 KB
input-034.txt AC 1 ms 384 KB
input-035.txt AC 1 ms 384 KB
input-036.txt AC 1 ms 384 KB
input-037.txt AC 1 ms 384 KB
input-038.txt AC 1 ms 384 KB
input-039.txt AC 1 ms 384 KB
input-040.txt AC 1 ms 384 KB
input-041.txt AC 1 ms 384 KB
input-042.txt AC 1 ms 384 KB
input-043.txt AC 1 ms 384 KB
input-044.txt AC 1 ms 384 KB
input-045.txt AC 1 ms 384 KB
input-046.txt AC 1 ms 384 KB
input-047.txt AC 1 ms 384 KB
input-048.txt AC 1 ms 384 KB
input-049.txt AC 1 ms 384 KB
input-050.txt AC 1 ms 384 KB
input-051.txt AC 1 ms 384 KB
input-052.txt AC 1 ms 384 KB
input-053.txt AC 2 ms 384 KB
input-054.txt AC 1 ms 384 KB
input-055.txt AC 1 ms 384 KB
input-056.txt AC 1 ms 384 KB
input-057.txt AC 1 ms 384 KB
input-058.txt AC 1 ms 384 KB
input-059.txt AC 2 ms 384 KB
input-060.txt AC 1 ms 384 KB
input-061.txt AC 1 ms 384 KB
input-062.txt AC 1 ms 384 KB
input-063.txt AC 1 ms 384 KB
input-064.txt AC 2 ms 384 KB
input-065.txt AC 1 ms 384 KB
input-066.txt AC 2 ms 384 KB
input-067.txt AC 2 ms 384 KB
input-068.txt AC 2 ms 384 KB
input-069.txt AC 2 ms 384 KB
input-070.txt AC 2 ms 384 KB
input-071.txt AC 2 ms 384 KB
input-072.txt AC 2 ms 384 KB
input-073.txt AC 2 ms 384 KB
input-074.txt AC 2 ms 384 KB
input-075.txt AC 2 ms 384 KB
input-076.txt AC 2 ms 384 KB
input-077.txt AC 2 ms 384 KB
input-078.txt AC 2 ms 384 KB
input-079.txt AC 2 ms 384 KB
input-080.txt AC 2 ms 384 KB
input-081.txt AC 2 ms 384 KB
input-082.txt AC 2 ms 384 KB
input-083.txt AC 2 ms 384 KB
input-084.txt AC 2 ms 384 KB
input-085.txt AC 2 ms 384 KB
input-086.txt AC 2 ms 384 KB
input-087.txt AC 2 ms 384 KB
input-088.txt AC 2 ms 384 KB
input-089.txt AC 2 ms 384 KB
input-090.txt AC 2 ms 384 KB
input-091.txt AC 2 ms 384 KB
input-092.txt AC 2 ms 384 KB
input-093.txt AC 2 ms 384 KB
input-094.txt AC 2 ms 384 KB
input-095.txt AC 2 ms 384 KB
input-096.txt AC 2 ms 384 KB
input-097.txt AC 2 ms 384 KB
input-098.txt AC 2 ms 384 KB
input-099.txt AC 3 ms 384 KB
input-100.txt AC 2 ms 384 KB