結果
問題 | No.653 E869120 and Lucky Numbers |
ユーザー |
![]() |
提出日時 | 2018-02-23 23:42:58 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 911 bytes |
コンパイル時間 | 1,433 ms |
コンパイル使用メモリ | 160,796 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-13 18:16:12 |
合計ジャッジ時間 | 2,273 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 31 |
ソースコード
#include<bits/stdc++.h> #define REP(i,n) for(int i=0;i<(n);i++) #define ALL(v) (v).begin(),(v).end() #define int long long #define INF 1e18 #define SIZE 200005 using namespace std; typedef pair<int,int> P; //----------------------------------------------------------------------- int a[SIZE]; signed main() { cin.tie(0); ios::sync_with_stdio(false); string s; cin>>s; int N=s.size(); REP(i,N) a[i]=s[i]-'0'; if(a[N-1]!=2 && a[N-1]!=3 && a[N-1]!=4){ cout<<"No"<<endl; return 0; } bool f=true; for(int i=N-1;i>=0;i--){ if(i==0){ if(a[i]!=0 && a[i]!=6 && a[i]!=7) f=false; break; } if(a[i]==2||a[i]==3||a[i]==4) a[i-1]--; else{ for(int j=i;j>=0;j--){ if(a[j]!=6 && a[j]!=7) f=false; } break; } } cout<<(f?"Yes":"No")<<endl; }