結果

問題 No.2989 Fibonacci Prize
ユーザー chestnut_68
提出日時 2024-12-15 02:19:10
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 60 ms / 2,000 ms
コード長 397 bytes
コンパイル時間 1,850 ms
コンパイル使用メモリ 169,804 KB
実行使用メモリ 43,928 KB
最終ジャッジ日時 2024-12-15 02:19:18
合計ジャッジ時間 6,096 ms
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
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(i=1;i<=T;i++)R[(F[i+2]-1+N)%N]+=((M-2)/T)+(i<=(M-2)%T?1:0);
	for(i=0,R[0]++;i<N;i++)a+=R[i]*(R[i]-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