https://cses.fi/paste/54fab72c7fe689a490ac0d/
#include<bits/stdc++.h>using namespace std;const int N =1e6 +10;int dp[N]; // guarda menor caminho de n para 0int main(){int n;cin >> n;dp[0] = 0;for(int num = 1;num <= n;num++){vector <int> d;int x = num;while(x > 0){int t = x % 10;d.push_back(t);x =x/10;}dp[num] = 1e7;for(auto y : d){dp[num] = min(dp[num], dp[num-y]+1);}}cout << dp[n] << '\n';}