結果

問題 No.1992 Tendon Walk
ユーザー ChocolateCornetChocolateCornet
提出日時 2022-07-07 20:47:22
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 4,170 bytes
コンパイル時間 1,567 ms
コンパイル使用メモリ 169,112 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-12-25 00:41:15
合計ジャッジ時間 2,109 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
5,248 KB
testcase_01 AC 2 ms
5,248 KB
testcase_02 AC 2 ms
5,248 KB
testcase_03 AC 2 ms
5,248 KB
testcase_04 AC 2 ms
5,248 KB
testcase_05 AC 2 ms
5,248 KB
testcase_06 AC 2 ms
5,248 KB
testcase_07 AC 2 ms
5,248 KB
testcase_08 AC 2 ms
5,248 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

//#include <bits/stdc++.h>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <exception>
#include <fstream>
#include <functional>
#include <iomanip>
#include <ios>
#include <iosfwd>
#include <iostream>
#include <istream>
#include <iterator>
#include <limits>
#include <list>
#include <locale>
#include <map>
#include <memory>
#include <new>
#include <numeric>
#include <ostream>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <stdexcept>
#include <streambuf>
#include <string>
#include <typeinfo>
#include <utility>
#include <valarray>
#include <vector>

#include <array>
#include <atomic>
#include <chrono>
#include <condition_variable>
#include <forward_list>
#include <future>
#include <initializer_list>
#include <mutex>
#include <random>
#include <ratio>
#include <regex>
#include <scoped_allocator>
#include <system_error>
#include <thread>
#include <tuple>
#include <typeindex>
#include <type_traits>
#include <unordered_map>
#include <unordered_set>
using namespace std;
using ll = long long;
#define _GLIBCXX_DEBUG
#define all(v) (v).begin(), (v).end()
#define rep(i, n) for(int i=0;i<n;++i)
using Graph = vector<vector<int>>;
ll MAX(ll x, ll y) {
    if (x >= y)return x;
    else return y;
}
ll MIN(ll x, ll y) {
    if (x >= y)return y;
    else return x;
}
ll gcd(ll x, ll y) {
    if (x < y)swap(x, y);
    if (y == 0)return x;
    return gcd(y, x % y);
}//最大公約数
ll lcm(ll a, ll b) {
    return (a / gcd(a, b)) * b;
}//最小公倍数
ll one_to_k(ll K) {
    return K * (K + 1) / 2;
}//1~Kまでの和
vector<pair<ll, ll>> prime_factorize(ll N) {
    vector<pair<ll, ll>>res;
    for (ll a = 2; a * a <= N; a++) {
        if (N % a != 0)continue;
        ll ex = 0;
        while (N % a == 0) {
            ex++;
            N /= a;
        }
        res.push_back({ a,ex });
    }
    if (N != 1)res.push_back({ N,1 });
    return res;
}//素因数分解O(√N)(素因数,指数)のpairの配列生成
//const auto &res = prime_factorize(N);
const ll INF = 7000000000000000000;
const ll inf = 1000000000 + 7;
ll MOD = 998244353;
// 定数
bool IsPrime(ll num) {
    if (num < 2) return false;
    else if (num == 2) return true;
    else if (num % 2 == 0) return false;
    double sqrtNum = sqrt(num);
    for (int i = 3; i <= sqrtNum; i += 2) {
        if (num % i == 0)return false;
    }
    return true;
}

long long pow_mod(long long x, long long n) {
    x %= MOD;
    long long ret = 1;
    while (n > 0) {
        if (n & 1) ret = (ret * x) % MOD;
        x = x * x % MOD;
        n >>= 1;
    }
    return ret;
}//繰り返し二乗法
long long nCr_mod(long long n, long long r) {
    long long x = 1, y = 1;
    for (int i = 0; i < r; i++) {
        x = x * (n - i) % MOD;
        y = y * (i + 1) % MOD;
    }
    return x * pow_mod(y, MOD - 2) % MOD;
}//nCrをMODで割った余りO(N)?
long long modinv(long long a, long long m) {
    long long b = m, u = 1, v = 0;
    while (b) {
        long long t = a / b;
        a -= t * b; swap(a, b);
        u -= t * v; swap(u, v);
    }
    u %= m;
    if (u < 0) u += m;
    return u;
}//割り算のMOD(逆元)
//aをbで割ったやつをmで割った余りは、
//(a%m)*modinv(b,m)%m;
//#include <atcoder/all>
//using namespace atcoder;
//priority_queue<int, vector<int>, greater<int>> pq;


int N;
double dp[310][310][301];
bool seen[310][310][301];
double f(int a, int b, int c) {
    if (a + b + c == 0)return 0;
    if (seen[a][b][c])return dp[a][b][c];
    seen[a][b][c] = true;
    double ret = 0; 
    ret += N;
    if (a > 0)ret += ((double)f(a - 1, b, c) * a);
    if (b > 0)ret += (double)(f(a + 1, b - 1, c) * b);
    if (c > 0)ret += (double)(f(a, b + 1, c - 1) * c);
    ret /= (double)(N - (double)(N - a - b - c));
   
    cout << ret << endl;
    return dp[a][b][c] = ret;
}

int main() {
    //cout << fixed << setprecision(15);

    int X;
    cin >> X;
    vector<int>d = { 2,2,-1,-1,2,-1,-1 };
    int i = 0;
    int now = 0, count = 0;
    while (true) {
        now += d[i];
        count+=abs(d[i]);
        if (now == X)break;
        i++;
        i %= 7;
    }
  
    cout<<count<<endl;
}
0