#ifdef LOCAL #include <local.hpp> #else #include <bits/stdc++.h> #define debug(...) ((void)0) #define postprocess(...) ((void)0) #endif #include <atcoder/modint.hpp> using mint = atcoder::modint998244353; namespace atcoder { template <int m, std::enable_if_t<(1 <= m)>* = nullptr> std::ostream& operator<<(std::ostream& os, const static_modint<m>& x) { return os << x.val(); } } // namespace atcoder using namespace std; using ll = long long; using ld = long double; void solve([[maybe_unused]] int test) { int N; cin >> N; vector<string> S(N); for (auto&& x : S) { cin >> x; } sort(S.begin(), S.end(), [](const string& a, const string& b) { return a + b < b + a; }); mint ans = 0; for (auto&& x : S) { for (auto&& c : x) { ans *= 10; ans += (c - '0'); } } cout << ans << endl; } int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int t = 1; // cin >> t; for (int i = 1; i <= t; i++) { solve(i); } postprocess(); }