結果

問題 No.42 貯金箱の溜息
ユーザー char134217728char134217728
提出日時 2017-08-25 22:19:26
言語 C++11
(gcc 13.3.0)
結果
AC  
実行時間 769 ms / 5,000 ms
コード長 4,550 bytes
コンパイル時間 1,704 ms
コンパイル使用メモリ 178,460 KB
実行使用メモリ 6,820 KB
最終ジャッジ日時 2024-10-15 15:45:32
合計ジャッジ時間 3,613 ms
ジャッジサーバーID
(参考情報)
judge3 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 47 ms
6,820 KB
testcase_01 AC 769 ms
6,820 KB
testcase_02 AC 587 ms
6,816 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp:167:1: warning: ISO C++ forbids declaration of ‘main’ with no type [-Wreturn-type]
  167 | main(){
      | ^~~~

ソースコード

diff #

#include <bits/stdc++.h>
#define FOR(i,a,b) for (int i=(a);i<(b);i++)
#define FORR(i,a,b) for (int i=(a);i>=(b);i--)
#define pb push_back
#define pcnt __builtin_popcount
#define show(x) cout<<#x<<" = "<<x<<endl;
#define maxs(x,y) x = max(x,y)
#define mins(x,y) x = min(x,y)
#define fi first
#define se second
#define rng(a) a.begin(),a.end()
#define each(it,c) for(__typeof((c).begin()) it=(c).begin();it!=(c).end();it++)
#define sz(x) (int)(x).size()

using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
typedef vector<int> vi;
typedef vector<vi> vvi;
typedef vector<pii> vpii;
typedef set<int> si;
typedef pair<ll,ll> pll;
typedef vector<ll> vl;
typedef vector<vl> vvl;
typedef vector<pll> vpll;
typedef set<ll> sl;
template<typename T>string join(vector<T>&v)
{stringstream s;FOR(i,0,sz(v))s<<' '<<v[i];return s.str().substr(1);}
ll gcd(ll a,ll b){if(a>b)swap(a,b);for(;a>0;b%=a,swap(a,b));return b;}
int modpow(ll a,ll n,int m){if(a==0)return a;ll p=1;for(;n>0;n/=2,a=a*a%m)if(n&1)p=p*a%m;return(int)p;}
void dout(double d){printf("%.12f\n",d);}

const int iinf = 1e9;
const ll linf = 1e18;
const int mod = 1e9+9;
const double eps = 1e-10;
const ll V[21] = {
  1, 99, 2450, 7350, 8600, 0,
  1, 49, 225, 350, 0,
  1, 9, 20, 0,
  1, 4, 0,
  1, 0,
  1
};
const ll G[100][5] = {
  1,0,0,0,0,
  1,1,0,0,0,
  1,2,1,0,0,
  1,3,2,0,0,
  1,4,4,0,0,
  1,5,6,0,0,
  1,6,9,0,0,
  1,7,12,0,0,
  1,8,16,0,0,
  1,9,20,0,0,
  1,10,25,1,0,
  1,11,30,2,0,
  1,12,36,4,0,
  1,13,42,6,0,
  1,14,49,9,0,
  1,15,56,12,0,
  1,16,64,16,0,
  1,17,72,20,0,
  1,18,81,25,0,
  1,19,90,30,0,
  1,20,100,37,1,
  1,21,110,44,2,
  1,22,121,53,4,
  1,23,132,62,6,
  1,24,144,73,9,
  1,25,156,84,12,
  1,26,169,97,16,
  1,27,182,110,20,
  1,28,196,125,25,
  1,29,210,140,30,
  1,30,225,158,37,
  1,31,240,176,44,
  1,32,256,197,53,
  1,33,272,218,62,
  1,34,289,242,73,
  1,35,306,266,84,
  1,36,324,293,97,
  1,37,342,320,110,
  1,38,361,350,125,
  1,39,380,380,140,
  1,40,400,414,159,
  1,41,420,448,178,
  1,42,441,486,201,
  1,43,462,524,224,
  1,44,484,566,251,
  1,45,506,608,278,
  1,46,529,654,309,
  1,47,552,700,340,
  1,48,576,750,375,
  1,49,600,800,410,
  1,50,625,855,451,
  1,51,650,910,492,
  1,52,676,970,539,
  1,53,702,1030,586,
  1,54,729,1095,639,
  1,55,756,1160,692,
  1,56,784,1230,751,
  1,57,812,1300,810,
  1,58,841,1375,875,
  1,59,870,1450,940,
  1,60,900,1531,1014,
  1,61,930,1612,1088,
  1,62,961,1699,1171,
  1,63,992,1786,1254,
  1,64,1024,1879,1346,
  1,65,1056,1972,1438,
  1,66,1089,2071,1539,
  1,67,1122,2170,1640,
  1,68,1156,2275,1750,
  1,69,1190,2380,1860,
  1,70,1225,2492,1982,
  1,71,1260,2604,2104,
  1,72,1296,2723,2238,
  1,73,1332,2842,2372,
  1,74,1369,2968,2518,
  1,75,1406,3094,2664,
  1,76,1444,3227,2822,
  1,77,1482,3360,2980,
  1,78,1521,3500,3150,
  1,79,1560,3640,3320,
  1,80,1600,3788,3506,
  1,81,1640,3936,3692,
  1,82,1681,4092,3894,
  1,83,1722,4248,4096,
  1,84,1764,4412,4314,
  1,85,1806,4576,4532,
  1,86,1849,4748,4766,
  1,87,1892,4920,5000,
  1,88,1936,5100,5250,
  1,89,1980,5280,5500,
  1,90,2025,5469,5770,
  1,91,2070,5658,6040,
  1,92,2116,5856,6330,
  1,93,2162,6054,6620,
  1,94,2209,6261,6930,
  1,95,2256,6468,7240,
  1,96,2304,6684,7570,
  1,97,2352,6900,7900,
  1,98,2401,7125,8250,
  1,99,2450,7350,8600
};

vvl matl;
vpii idxl;
map<pii, int> idxh;
void merge(vl&a, vl&b, vl&c){
  vl tmp;
  tmp.resize(21);
  FOR(s, 0, 21){
    ll t = 0;
    int i = idxl[s].fi, j = idxl[s].se;
    FOR(k, i, j+1){
      FOR(l, k, j+1){
        t += a[idxh[pii(i, k)]] * b[idxh[pii(l, j)]];
        t %= mod;
      }
    }
    tmp[s] = t;
  }
  FOR(i, 0, 21)c[i] = tmp[i];
}
main(){
  cin.tie(0);
  ios::sync_with_stdio(false);
  FOR(i, 0, 6)FOR(j, i, 6){
    idxh[pii(i, j)] = sz(idxl);
    idxl.pb(pii(i, j));
  }
  matl.resize(63);
  matl[0].resize(21);
  FOR(i, 0, 21)matl[0][i] = V[i];
  FOR(i, 1, 63){
    matl[i].resize(21);
    merge(matl[i-1], matl[i-1], matl[i]);
  }
  int t;
  cin >> t;
  FOR(i, 0, t){
    ll m, n;
    cin >> m;
    n = m % 500;
    n /= 5;
    m /= 500;
    if(m==0){
      ll ans = 0;
      FOR(j, 0, 5)ans += G[n][j];
      cout << ans%mod << endl;
      continue;
    }
    int c = 0;
    while(!(m&1)){
      c++;
      m /= 2;
    }
    vl h = matl[c];
    c++;
    m /= 2;
    while(m > 0){
      if(m&1)merge(matl[c], h, h);
      c++;
      m /= 2;
    }
    ll ans = 0;
    FOR(j, 0, 5){
      FOR(k, j, 6){
        FOR(l, k, 6){
          ans += G[n][j] * h[idxh[pii(k, l)]];
          ans %= mod;
        }
      }
    }
    cout << ans << endl;
  }
}
0