結果
| 問題 | 
                            No.2120 場合の数の下8桁
                             | 
                    
| コンテスト | |
| ユーザー | 
                             259_Momone
                         | 
                    
| 提出日時 | 2022-11-04 22:28:25 | 
| 言語 | C++17  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 180 ms / 2,000 ms | 
| コード長 | 1,361 bytes | 
| コンパイル時間 | 2,281 ms | 
| コンパイル使用メモリ | 246,860 KB | 
| 最終ジャッジ日時 | 2025-02-08 18:03:30 | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge5 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 20 | 
ソースコード
#include <bits/extc++.h>
int main() {
    using namespace std;
    constexpr unsigned long mod{100000000};
    unsigned long M, N;
    cin >> M >> N;
    unsigned long value_p{1}, ord_2_p{}, ord_5_p{};
    unsigned long value_m{1}, ord_2_m{}, ord_5_m{};
    if(N > M){
        printf("%08lu\n", 0UL);
        return 0;
    }
    const auto multiplies{[](unsigned long& value, unsigned long& ord_2, unsigned long& ord_5, unsigned long x){
        while(x && x % 2 == 0){
            ++ord_2;
            x /= 2;
        }
        while(x && x % 5 == 0){
            ++ord_5;
            x /= 5;
        }
        (value *= x) %= mod;
    }};
    for(unsigned long i{}; i < N; ++i){
        multiplies(value_p, ord_2_p, ord_5_p, M - i);
        multiplies(value_m, ord_2_m, ord_5_m, i + 1);
    }
    assert(ord_2_p >= ord_2_m);
    assert(ord_5_p >= ord_5_m);
    auto ord_2{ord_2_p - ord_2_m};
    auto ord_5{ord_5_p - ord_5_m};
    auto value{[](unsigned long a, unsigned long n, unsigned long b){
        while(n){
            if(n & 1)(b *= a) %= mod;
            (a *= a) %= mod;
            n /= 2;
        }
        return b;
    }(value_m, 4999999, value_p)};
    while(ord_2 > 0){
        --ord_2;
        (value *= 2) %= mod;
    }
    while(ord_5 > 0){
        --ord_5;
        (value *= 5) %= mod;
    }
    printf("%08lu\n", value);
    return 0;
}
            
            
            
        
            
259_Momone