#include #include #include #include namespace mp = boost::multiprecision; // 任意長整数型 using Bint = mp::cpp_int; // 仮数部が10進数で1024桁の浮動小数点数型(TLEしたら小さくする) using Real = mp::number>; using namespace std; using namespace atcoder; using ll = long long; using mint = modint998244353; using vi = vector; using vvi = vector; using vvvi = vector; using vll = vector; using vvll = vector; using vvvll = vector; using vmi = vector; using vvmi = vector; using vvvmi = vector; #define all(a) (a).begin(), (a).end() #define rep2(i, m, n) for (int i = (m); i < (n); ++i) #define rep(i, n) rep2(i, 0, n) #define drep2(i, m, n) for (int i = (m)-1; i >= (n); --i) #define drep(i, n) drep2(i, n, 0) void solve(){ ll n, m; cin >> n >> m; set st; st.insert(1); vi v(1, 1); ll a = 1; int loopstart; while(true){ a *= n; a %= 998; if(st.count(a)){ loopstart = a; break; } v.push_back(a); st.insert(a); } int slen = v.size(); vector vs(slen, v[0]); rep2(i, 1, slen)vs[i] = vs[i-1] + v[i]; vector vl(1, loopstart); set st2; st2.insert(loopstart); a = loopstart; while(true){ a*=n; a %= 998; if(st2.count(a))break; vl.push_back(a); st2.insert(a); } int llen = vl.size(); Bint s = 0; rep(i, llen)s+= vl[i]; vector r(llen, 0); rep(i, llen-1){ r[i+1] = r[i] + vl[i]; r[i+1] %= 998; } rep(i, m){ Bint k; cin >> k; k++; if(n == 0){ cout << 1 << endl; continue; } if(k <= slen){ cout << vs[(int)(k-1)]%998 << endl; continue; } k -= slen; Bint loop = k/(Bint)llen; Bint ans = loop*s + vs[slen-1]; int amari = (int)(k % (Bint)llen); cout << (ans + r[amari])%998 << endl; } } int main(){ ios::sync_with_stdio(false); cin.tie(nullptr); int t; cin >> t; while(t--)solve(); return 0; }