結果
問題 | No.492 IOI数列 |
ユーザー |
![]() |
提出日時 | 2017-04-04 16:59:56 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 1,000 ms |
コード長 | 1,733 bytes |
コンパイル時間 | 1,067 ms |
コンパイル使用メモリ | 100,976 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-08 08:36:36 |
合計ジャッジ時間 | 1,684 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 19 |
ソースコード
#include <iostream>#include <fstream>#include <typeinfo>#include <vector>#include <stack>#include <cmath>#include <set>#include <map>#include <string>#include <algorithm>#include <cstdio>#include <queue>#include <iomanip>#include <cctype>#include <random>#define syosu(x) fixed<<setprecision(x)using namespace std;typedef long long ll;typedef unsigned long long ull;typedef pair<int,int> P;typedef pair<double,double> pdd;typedef pair<ll,ll> pll;typedef vector<int> vi;typedef vector<vi> vvi;typedef vector<double> vd;typedef vector<vd> vvd;typedef vector<ll> vl;typedef vector<vl> vvl;typedef vector<char> vc;typedef vector<vc> vvc;typedef vector<string> vs;typedef vector<bool> vb;typedef vector<vb> vvb;typedef vector<P> vp;typedef vector<vp> vvp;typedef vector<pll> vpll;typedef pair<int,P> pip;typedef vector<pip> vip;const int inf=1<<30;const ll INF=1ll<<57;const double pi=acos(-1);const double eps=1e-6;const ll mod=1e9+7;const int dx[4]={0,1,0,-1},dy[4]={1,0,-1,-0};const int DX[8]={-1,-1,-1,0,1,1,1,0},DY[8]={1,0,-1,-1,-1,0,1,1};vvl mul(vvl A,vvl B){vvl C(A.size(),vl(B[0].size()));for(int i=0;i<A.size();i++) for(int k=0;k<B.size();k++) for(int j=0;j<B[0].size();j++) (C[i][j]+=A[i][k]*B[k][j])%=mod;return C;}vvl pow(vvl A,ll n){vvl B(A.size(),vl(A.size()));for(int i=0;i<A.size();i++) B[i][i]=1;while(n>0){if(n&1) B=mul(B,A);A=mul(A,A);n>>=1;}return B;}ll n;int main(){cin>>n;vvl a(2,vl(2)),b(2,vl(1));a[0][0]=100;a[0][1]=1;a[1][0]=0;a[1][1]=1;a=pow(a,n-1);cout<<(a[0][0]+a[0][1])%mod<<endl;n%=11;if(!n) cout<<0<<endl;else{string s;for(int i=0;i<n;i++) s+="01";for(int i=1;i<2*n;i++) cout<<s[i];cout<<endl;}}