結果
| 問題 | No.42 貯金箱の溜息 | 
| コンテスト | |
| ユーザー |  gaokai2050 | 
| 提出日時 | 2022-11-10 13:05:35 | 
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 36 ms / 5,000 ms | 
| コード長 | 741 bytes | 
| コンパイル時間 | 1,693 ms | 
| コンパイル使用メモリ | 168,832 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-07-23 15:31:36 | 
| 合計ジャッジ時間 | 2,333 ms | 
| ジャッジサーバーID (参考情報) | judge5 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 3 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=1000000009;
inline void add(ll &x,ll y) { x+=y; if (x>=mod) x-=mod; }
ll dp[100501];
ll rev(ll a) {
	ll r=1, n=mod-2;
	while(n) {
		if (n&1) r=r*a%mod;
		a=a*a%mod,n>>=1;
	}
	return r;
}
ll solve(ll x) {
	ll q=x/500,r=x%500,ret=0;	
	for (int i=0;i<=6;++i) {
		ll a=1,b=1;
		for (int j=0;j<=6;++j)
			if (i!=j) a=a*(mod-(q-j)%mod)%mod;
		for (int j=0;j<=6;++j)
			if (i!=j) b=b*(mod-(i-j))%mod;
		add(ret,dp[r+i*500]*a%mod*rev(b));
	}	
	return ret%mod;
}
int main() {
	int a[10]={0,1,5,10,50,100,500};
	dp[0]=1;
	for (int i=1;i<=6;++i)
		for (int j=a[i];j<=100000;++j)
			add(dp[j],dp[j-a[i]]);
	int T; ll x;
	cin>>T;
	while (T--) cin>>x,cout<<solve(x)<<endl;
}
            
            
            
        