結果
| 問題 | No.1595 The Final Digit |
| コンテスト | |
| ユーザー |
alorie10
|
| 提出日時 | 2021-07-09 21:50:31 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 689 bytes |
| コンパイル時間 | 1,476 ms |
| コンパイル使用メモリ | 166,104 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-01 15:56:13 |
| 合計ジャッジ時間 | 2,180 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 17 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,ans,a,b,c,dp[2001],A,B,d,ord[2001];
int main(void){
cin>>a>>b>>c>>n;
a%=10,b%=10,c%=10;
A=100*a+10*b+c;
memset(dp,-1,sizeof(dp));
//dp[0]=a,dp[1]=b,dp[2]=c;
ord[0]=a,ord[1]=b,ord[2]=c;
for(int i=3;i<2000;i++){
d=(a+b+c)%10;
a=b;
b=c;
c=d;
if(dp[100*a+10*b+c]!=-1){B=i,A=dp[100*a+10*b+c];break;}
else{
dp[100*a+10*b+c]=i;
ord[i]=d;
}
}
//cout<<A<<" "<<B<<endl;
if(n<=A)cout<<dp[n-1]<<endl;
else{
n-=A+1;
n%=B-A;
//cout<<n+A<<endl;
cout<<ord[n+A]<<endl;
}
}
alorie10