結果
| 問題 |
No.3316 Make 81181819 with only 0,1,or 8
|
| コンテスト | |
| ユーザー |
tau1235
|
| 提出日時 | 2025-10-31 21:52:47 |
| 言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 6,000 ms |
| コード長 | 2,174 bytes |
| コンパイル時間 | 3,552 ms |
| コンパイル使用メモリ | 298,348 KB |
| 実行使用メモリ | 7,716 KB |
| 最終ジャッジ日時 | 2025-10-31 21:52:52 |
| 合計ジャッジ時間 | 4,516 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 22 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
int m=7;
vector<vector<int>> cand(m+1);
vector<vector<vector<int>>> vec(m+1,vector<vector<int>>(100));
void solve(){
using ll=long long;
ll n;
cin>>n;
string s=to_string(81181819-n);
reverse(s.begin(),s.end());
int k=10;
while (s.size()<k) s+="0";
vector<vector<bool>> dp(k+1,vector<bool>(10));
vector prev(k+1,vector<pair<int,int>>(10));
dp[0][0]=true;
prev[0][0]={-1,-1};
for (int a=0;a<=m;a++){
for (int i=0;i<k;i++){
for (int j=0;j<10;j++){
if (!dp[i][j]) continue;
for (int c:cand[a]){
if ((j+c)%10!=s[i]-'0') continue;
dp[i+1][(j+c)/10]=true;
prev[i+1][(j+c)/10]={j,c};
}
}
}
if (dp[k][0]){
cout<<a<<endl;
vector<ll> ans(a);
ll now=0;
ll pw=1;
for (int i=0;i<k;i++) pw*=10;
for (int i=k;i>0;i--){
pw/=10;
auto p=prev[i][now];
now=p.first;
for (int j=0;j<a;j++){
ans[j]+=pw*vec[a][p.second][j];
}
}
for (int i=0;i<a;i++) cout<<ans[i]<<endl;
return;
}
}
}
int main(){
vector<int> mem;
auto dfs=[&](auto dfs,int v,int k=0){
cand[k].push_back(v);
vec[k][v]=mem;
if (k==m) return;
for (int i:{0,1,8}){
mem.push_back(i);
dfs(dfs,v+i,k+1);
mem.pop_back();
}
};
dfs(dfs,0);
for (int i=0;i<=m;i++) cand[i].erase(unique(cand[i].begin(),cand[i].end()),cand[i].end());
int t;
cin>>t;
while (t--) solve();
}
/*
using ll=long long;
ll m=81181819+10;
ll inf=1e9;
vector<ll> vec;
vector<ll> d(m,inf);
void solve(){
ll n;
cin>>n;
cout<<d[n]<<endl;
}
int main(){
auto dfs=[&](auto dfs,ll v){
if (v) vec.push_back(v);
if (v>=m) return;
for (int u:{0,1,8}){
if (v==0&&u==0) continue;
dfs(dfs,v*10+u);
}
};
dfs(dfs,0);
sort(vec.begin(),vec.end());
queue<int> q;
d[0]=0;
q.push(0);
while (!q.empty()){
int v=q.front();
q.pop();
for (int u:vec){
int nv=v+u;
if (nv>=m) break;
if (d[nv]!=inf) continue;
d[nv]=d[v]+1;
q.push(nv);
}
}
int t;
cin>>t;
while (t--) solve();
}
*/
tau1235