結果
問題 | No.167 N^M mod 10 |
ユーザー |
|
提出日時 | 2024-10-14 13:49:42 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,652 bytes |
コンパイル時間 | 6,037 ms |
コンパイル使用メモリ | 316,208 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-10-14 13:49:49 |
合計ジャッジ時間 | 7,046 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 21 WA * 6 |
ソースコード
#include<bits/stdc++.h>#include<atcoder/all>namespace my{void main();void solve();}int main(){my::main();}namespace my{#define eb emplace_back#define FO(n) for(ll ij=n;ij--;)#define FOR(i,...) for(auto[i,i##stop,i##step]=range(0,__VA_ARGS__);i<i##stop;i+=i##step)#define fo(i,...) FO##__VA_OPT__(R)(i __VA_OPT__(,__VA_ARGS__))#define fe(a,i,...) for(auto&&__VA_OPT__([)i __VA_OPT__(,__VA_ARGS__]):a)using namespace std;using ll=long long;using ull=unsigned long long;using ulll=__uint128_t;using lll=__int128_t;istream&operator>>(istream&i,ulll&x){ull t;i>>t;x=t;return i;}ostream&operator<<(ostream&o,const ulll&x){return(x<10?o:o<<x/10)<<ll(x%10);}istream&operator>>(istream&i,lll&x){ll t;i>>t;x=t;return i;}ostream&operator<<(ostream&o,const lll&x){return o<<string(x<0,'-')<<ulll(x>0?x:-x);}auto range(bool s,ll a,ll b=1e18,ll c=1){if(b==1e18)b=a,(s?b:a)=0;return array{a-s,b,c};}constexpr char nl=10;constexpr char sp=32;lll pw(lll x,ll n,ll m=0){assert(n>=0);lll r=1;while(n)n&1?r*=x:r,x*=x,m?r%=m,x%=m:r,n>>=1;return r;}template<class V>concept vectorial=is_base_of_v<vector<typename V::value_type>,V>;template<class V>istream&operator>>(istream&i,vector<V>&v){fe(v,e)i>>e;return i;}template<class V>ostream&operator<<(ostream&o,const vector<V>&v){fe(v,e)o<<e<<string(&e!=&v.back(),vectorial<V>?nl:sp);return o;}template<class V>struct vec:vector<V>{using vector<V>::vector;vec(const vector<V>&v){vector<V>::operator=(v);}vec&operator+=(const vec&u){vec&v=*this;fo(i,v.size())v[i]+=u[i];return v;}vec&operator-=(const vec&u){vec&v=*this;fo(i,v.size())v[i]-=u[i];return v;}vec&operator^=(const vec&u){this->insert(this->end(),u.begin(),u.end());return*this;}vec operator+(const vec&u)const{return vec{*this}+=u;}vec operator-(const vec&u)const{return vec{*this}-=u;}vec operator^(const vec&u)const{return vec{*this}^=u;}vec&operator++(){fe(*this,e)++e;return*this;}vec&operator--(){fe(*this,e)--e;return*this;}vec operator-()const{vec v=*this;fe(v,e)e=-e;return v;}};void io(){cin.tie(nullptr)->sync_with_stdio(0);cout<<fixed<<setprecision(15);}void lin(auto&...a){(cin>>...>>a);}auto sinen(const string&b="a"){string s;lin(s);vec<ll>r;fe(s,e)r.eb(b.size()==1?e-b[0]:b.find_first_of(e));return r;}auto sinen(ll n,const string&b="a"){vec<vec<ll>>r;fo(n)r.eb(sinen(b));return r;}template<char c=sp>void pp(const auto&...a){ll n=sizeof...(a);((cout<<a<<string(--n>0,c)),...);cout<<nl;}void main(){io();ll T=1;fo(T)solve();}void solve(){auto s=sinen("0");auto t=sinen("0");ll N=s.back();ll M=t.end()[-1];if(t.size()>=2)M+=t.end()[-2]*10;pp(pw(N,M,10));}}