結果

問題 No.2989 Fibonacci Prize
ユーザー chestnut_68
提出日時 2024-12-15 02:27:19
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 72 ms / 2,000 ms
コード長 381 bytes
コンパイル時間 1,893 ms
コンパイル使用メモリ 167,944 KB
実行使用メモリ 43,904 KB
最終ジャッジ日時 2024-12-15 02:27:26
合計ジャッジ時間 5,888 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 77
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function 'int main()':
main.cpp:4:21: warning: 'T' may be used uninitialized [-Wmaybe-uninitialized]
    4 |         int64_t N,M,T,a=0,i=1;cin>>N>>M;
      |                     ^

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
int main(){
	int64_t N,M,T,a=0,i=1;cin>>N>>M;
	vector<int64_t>F(5e6,1),R(N,0);
	for(F[0]=0;F[i]||F[i+1]>1;T=++i)F[i+2]=(F[i+1]+F[i])%N;
	for(R[0]++;i;i--)R[(F[i+2]-1+N)%N]+=((M-2)/T)+(i<=(M-2)%T?1:0);
	for(auto r:R)a+=r*(r-1)/2;
	if(N==1)a=(M-1)*(M-2)/2;
	if(F[(M-1)%T]%N==0)a++;
	if(F[M%T]%N==0)a+=2;
	if(M<3)a=(N==1?2:0);
	cout<<a;
}
0