結果
| 問題 |
No.1258 コインゲーム
|
| コンテスト | |
| ユーザー |
👑 SPD_9X2
|
| 提出日時 | 2020-10-16 23:08:56 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 1,466 ms / 2,000 ms |
| コード長 | 1,750 bytes |
| コンパイル時間 | 2,365 ms |
| コンパイル使用メモリ | 205,096 KB |
| 最終ジャッジ日時 | 2025-01-15 09:16:22 |
|
ジャッジサーバーID (参考情報) |
judge1 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 50 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:70:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
70 | scanf("%d",&S);
| ~~~~~^~~~~~~~~
main.cpp:73:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
73 | scanf("%lld %lld %lld",&N,&M,&X);
| ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~
ソースコード
/*
https://yukicoder.me/problems/no/1258
行列累乗では?
dp[i][x] = i番目までのコインを投げて、表がx(mod2で)回出たときのスコア
表が出たとき
dp[i+1][x^1] += dp[i][x] * M
裏が出たとき
dp[i+1][x] += dp[i][x]
*/
#include <bits/stdc++.h>
using namespace std;
#define rep(i,n,m) for(ll (i)=(n);(i)<(m);(i)++)
#define rrep(i,n,m) for(ll (i)=(n);(i)>(m);(i)--)
using ll = long long;
const ll mod = 1000000007;
vector<vector<ll>> matrix_mul(vector<vector<ll>> A,vector<vector<ll>> B){
vector<vector<ll>> ans(A.size(),vector<ll> (B[0].size(),0));
rep(ai,0,A.size()){
rep(bj,0,B[0].size()){
ll now = 0;
rep(same,0,A[0].size()){
now += A[ai][same] * B[same][bj];
}
if (mod > 0){
ans[ai][bj] = now % mod;
}else{
ans[ai][bj] = now;
}
}
}
return ans;
}
vector<vector<ll>> matrix_pow(vector<vector<ll>> A,ll x){
vector<vector<ll>> B(A.size(),vector<ll> (A[0].size(),0));
rep(i,0,A.size()){
rep(j,0,A[0].size()){
B[i][j] = A[i][j];
}
}
vector<vector<ll>> ans(A.size(),vector<ll> (A[0].size(),0));
rep(i,0,A.size()) ans[i][i] = 1;
while (x > 0){
if (x % 2 == 1){
ans = matrix_mul(ans,B);
}
B = matrix_mul(B,B);
x /= 2;
}
return ans;
}
int main(){
int S;
scanf("%d",&S);
rep(loop,0,S){
ll N,M,X;
scanf("%lld %lld %lld",&N,&M,&X);
vector<vector<ll>> A = {{1,0}};
vector<vector<ll>> H = {{1,M},{M,1}};
vector<vector<ll>> ans = matrix_mul(A , matrix_pow(H,N));
printf("%lld\n",ans[0][X]);
}
}
SPD_9X2