結果

問題 No.2989 Fibonacci Prize
ユーザー chestnut_68
提出日時 2024-12-15 01:53:26
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 72 ms / 2,000 ms
コード長 451 bytes
コンパイル時間 1,729 ms
コンパイル使用メモリ 167,812 KB
実行使用メモリ 43,776 KB
最終ジャッジ日時 2024-12-15 01:53:34
合計ジャッジ時間 7,321 ms
ジャッジサーバーID
(参考情報)
judge2 / 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;cin>>N>>M;
      |                     ^

ソースコード

diff #

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