#include using namespace std; using ll=long long; #include #include #include #include #define pc_u putchar #pragma GCC target ("avx") #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #define rep(i,a,b) for(it i=(it)(a);i<(it)b;i++) #define rep2(i,a,b,c) for(it i=(it)(a);i<(it)b;i+=(it)c) #define repp(i,a,b) for(it i=(it)(a);i<=(it)b;i++) #define repp2(i,a,b,c) for(it i=(it)(a);i<=(it)b;i+=(it)c) #define irep(i,a,b) for(int i=(int)(a);i<(int)b;i++) #define irep2(i,a,b,c) for(int i=(int)(a);i<(int)b;i+=c) #define irepp(i,a,b) for(int i=(int)(a);i<=(int)b;i++) #define irepp2(i,a,b,c) for(int i=(int)(a);i<=(int)b;i+=c) #define nrep(i,a,b) for(it i=(it)(a)-1;i>=(it)b;i--) #define nrepp(i,a,b) for(it i=(it)(a);i>=(it)b;i--) #define inrep(i,a,b) for(int i=(int)(a)-1;i>=(int)b;i--) #define inrepp(i,a,b) for(int i=(int)(a);i>=(int)b;i--) #define inrep2(i,a,b,c) for(int i=(int)(a)-1;i>=(int)b;i-=c) #define inrepp2(i,a,b,c) for(int i=(int)(a);i>=(int)b;i-=c) #define all(v) v.begin(), v.end() #define rall(v) v.rbegin(), v.rend() #define Min(x) *min_element(all(x)) #define Max(x) *max_element(all(x)) #define popcount(x) __builtin_popcountll(x) #define moda 998244353LL #define modb 1000000007LL #define modc 968244353LL #define dai 2502502502502502502LL #define sho -dai #define aoi 1e18+1e6 #define giri 1010000000 #define en 3.14159265358979 #define eps 1e-14 #define fi first #define se second #define elif else if template using pq=priority_queue; template using pqg=priority_queue,greater>; #define uni(a) a.erase(unique(all(a)),a.end()) using it=long long; using itn=int; using un=unsigned long long; using idb=double; using db=long double; using st=string; using ch=char; using bo=bool; using P=pair; using ip=pair; using vi=vector; using ivi=vector; using ivd=vector; using vd=vector; using vs=vector; using vc=vector; using vb=vector; using vp=vector

; using ivp=vector; using sp=set

; using isp=set; using ss=set; using sca=set; using si=set; using isi=set; using svi=set; using svb=set; using vvi=vector; using ivvi=vector; using ivvd=vector; using vvd=vector; using vvs=vector; using vvb=vector; using vvc=vector; using vvp=vector; using ivvp=vector; using vsi=vector; using ivsi=vector; using isvi=set; using vsc=vector; using vsp=vector; using ivsp=vector; using vvsi=vector; using ivvsi=vector; using vvsp=vector; using ivvsp=vector; using svvb=set; using vvvi=vector; using ivvvi=vector; using ivvvd=vector; using vvvd=vector; using vvvb=vector; using ivvvp=vector; using vvvp=vector; using vvvvi=vector; using ivvvvi=vector; using vvvvd=vector; using vvvvb=vector; using ivvvvp=vector; using vvvvp=vector; using ivvvvvi=vector; using vvvvvi=vector; using ivvvvvvi=vector; using vvvvvvi=vector; using ivvvvvvvi=vector; using vvvvvvvi=vector; using vvvvvvvvi=vector; const int dx[8]={0,1,0,-1,1,1,-1,-1}; const int dy[8]={1,0,-1,0,1,-1,1,-1}; st abc="abcdefghijklmnopqrstuvwxyz"; st ABC="ABCDEFGHIJKLMNOPQRSTUVWXYZ"; st num="0123456789"; st mb="xo"; st MB="XO"; #include #include using namespace __gnu_pbds; template using ordered_multiset = tree, rb_tree_tag, tree_order_statistics_node_update>; namespace { template ostream &operator<<(ostream &os, const pair &p) { os << p.first << " " << p.second; return os; } template istream &operator>>(istream &is, pair &p) { is >> p.first >> p.second; return is; } template ostream &operator<<(ostream &os, const vector &v) { int s = (int)v.size(); for (int i = 0; i < s; i++) os << (i ? " " : "") << v[i]; return os; } template istream &operator>>(istream &is, vector &v) { for (auto &x : v) is >> x; return is; } istream &operator>>(istream &is, __int128_t &x) { string S; is >> S; x = 0; int flag = 0; for (auto &c : S) { if (c == '-') { flag = true; continue; } x *= 10; x += c - '0'; } if (flag) x = -x; return is; } istream &operator>>(istream &is, __uint128_t &x) { string S; is >> S; x = 0; for (auto &c : S) { x *= 10; x += c - '0'; } return is; } ostream &operator<<(ostream &os, __int128_t x) { if (x == 0) return os << 0; if (x < 0) os << '-', x = -x; string S; while (x) S.push_back('0' + x % 10), x /= 10; reverse(begin(S), end(S)); return os << S; } ostream &operator<<(ostream &os, __uint128_t x) { if (x == 0) return os << 0; string S; while (x) S.push_back('0' + x % 10), x /= 10; reverse(begin(S), end(S)); return os << S; } void input() {} template void input(T &t, U &...u) { cin >> t; input(u...); } template void input1(T &t, U &...u) { input(u...); } void print() { cout << "\n"; } template void print(const T &t, const U &...u) { cout << t; if (sizeof...(u)) cout << sep; print(u...); } template void print1(const T &t, const U &...u) { print(u...); } struct IoSetupNya { IoSetupNya() { cin.tie(nullptr); ios::sync_with_stdio(false); cout << fixed << setprecision(15); cerr << fixed << setprecision(7); } } iosetupnya; } //namespace Nyaan template T Sum(vector &a){ T s=0; for(auto i:a)s+=i; return s; } template T Sum(vector &a,int l,int r){ T s=0; irep(i,l,r)s+=a[i]; return s; } template void dec(vector &t,T k=1){ for(auto &i:t)i-=k; } template void inc(vector &t,T k=1){ for(auto &i:t)i+=k; } template vector make_vec(int n,T t){ vector g(n); for(auto &i:g)i=t; return g; } template vector subvec(vector a,int f,int l){ vector g(l); irep(i,f,f+l)g[i-f]=a[i]; return g; } template T gcda(T a,T b){ if(!a||!b)return max(a,b); while(a%b&&b%a){ if(a>b)a%=b; else b%=a; } return min(a,b); } it lcma(it a,it b){ return a/gcda(a,b)*b; } db distance(db a,db b,db c,db d){return sqrt((a-c)*(a-c)+(b-d)*(b-d));} db getAngle(db xa, db ya, db xb, db yb, db xc, db yc) { //角BACを求める //E8さんの記事コピペ db VectorAB = sqrt((xb - xa) * (xb - xa) + (yb - ya) * (yb - ya)); db VectorAC = sqrt((xc - xa) * (xc - xa) + (yc - ya) * (yc - ya)); db Naiseki = (xb - xa) * (xc - xa) + (yb - ya) * (yc - ya); db cosTheta = Naiseki / (VectorAB * VectorAC); return acos(cosTheta) * 180.0 / 3.14159265358979; } long double segment_origin_dist(long double A, long double B, long double C, long double D) { // P = (A,B), Q = (C,D) long double vx = C - A, vy = D - B; // ベクトルPQ long double wx = -A, wy = -B; // ベクトルPO (O-P) long double vv = vx * vx + vy * vy; // |PQ|^2 if (vv == 0) { // P == Q の場合、点と原点の距離 return sqrt(A * A + B * B); } long double t = (wx * vx + wy * vy) / vv; // 射影パラメータ long double nx, ny; // 最近点 if (t <= 0) { nx = A; ny = B; } else if (t >= 1) { nx = C; ny = D; } else { nx = A + t * vx; ny = B + t * vy; } return sqrt(nx * nx + ny * ny); } bo outc(int h,int w,int x,int y){ return (x<0||x>=h||y<0||y>=w); } template vector> nep(vector a){ vector> e; sort(all(a)); do{ e.emplace_back(a); }while(next_permutation(all(a))); return e; } template void chmin(T &a,T b){a=min(a,b);} template void chmax(T &a,T b){a=max(a,b);} void yn(bo a){print(a?string("Yes"):string("No"));} void YN(bo a){print(a?string("YES"):string("NO"));} struct dsu1{ ivi par,siz; dsu1(int n){ init(n); } void init(int n){ irep(i,0,n){ par.emplace_back(i); } siz.resize(n,1); } int leader(int u){ if(par[u]==u)return u; return par[u]=leader(par[u]); } void merge(int u,int v){ int ru=leader(u),rv=leader(v); if(ru==rv)return; if(size(ru) &e,int n){ /* 与えられた辺を持つグラフの最小全域木を求める 存在する場合はその答えを 存在しないならinf 計算量はO(MlogM+N)くらい */ vector g=e;sort(all(g),comppppp); it ans=0; dsu1 uf(n); for(auto i:g){ if(!uf.same(i.f,i.t)){ uf.merge(i.f,i.t); ans+=i.l; } } if(uf.size(0)==n)return ans; return dai; } #include using namespace atcoder; using mints=modint998244353; using mint=modint; using minto=modint1000000007; using vm=vector; using vms=vector; using vmo=vector; using vvm=vector; using vvms=vector; using vvmo=vector; using vvvm=vector; using vvvms=vector; using vvvmo=vector; using vvvvm=vector; using vvvvms=vector; using vvvvmo=vector; using vvvvvm=vector; using vvvvvms=vector; using vvvvvmo=vector; using vvvvvvm=vector; using vvvvvvms=vector; using vvvvvvmo=vector; using vvvvvvvms=vector; using vvvvvvvmo=vector; /*総和をもとめるセグ木 struct nod{ it val; nod(it v=0):val(v){} }; nod op(nod a,nod b){return nod(a.val+b.val);} nod e(){return nod(0);} struct act{ it a; act(it e=0):a(e){} }; nod mapping(act f,nod x){return nod(f.a+x.val);} act comp(act f,act g){return act(f.a+g.a);} act id(){return act(0);}*/ //#define endl '\n' //#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native") void solve(){ st s;input(s); int n=s.size(); ivvvi f(n,ivvi(n,ivi(n))); irep(i,0,n-2) irep(j,i+1,n-1) irep(k,j+1,n) if(s[j]==s[k]&&s[i]!='0'&&s[i]!=s[j])f[i][j][k]=(s[i]-'0')*100+(s[j]-'0')*10+(s[k]-'0')*1; ivi dp(1<