#include <vector>
#include <iostream>
#include <string>
#include <cstdlib>
#include <stdlib.h>
using namespace std;
long long int taken = 1;
int originalnum;
int main()
{
int wait;
int q;
long int b = 0;
cin >> q;
vector<long long int> queries = {};
for (long long int t = 1; t <= q; t++)
{
long long int tempq;
cin >> tempq;
queries.push_back(tempq);
}
for(long long int query : queries)
{
b++;
long long int i = 1;
long long int num = query;
long long int nextsub = 0;
long long int sub = 1;
long long int region = 1;
long long nums;
if (num <= 9)
{
}
else
{
while (num > nextsub)
{
long long tempnum = num;
sub = i * 9 * pow(10, i - 1);
nextsub = i * 9 * pow(10, i);
if (num - sub > 0)
{
num = num - sub;
region++;
}
else
{
//cout << "nada" << endl;
}
//cout << "NUM: " << num << ", SUB: " << sub << endl;
i++;
}
}
//cout << "REGION: " << region << " NUMS: " << region * 9 * pow(10, region - 1) << endl;
nums = region * 9 * pow(10, region - 1);
long long calc = (num - 1) / region + pow(10, region - 1);
//cout << "CALCULATION: " << calc << endl;
string result = to_string(calc);
long long pos = (num - 1) % region;
//cout << "POS: "<< pos << endl;
if (b < queries.size())
{
cout << result[pos] << endl;
}
else
{
cout << result[pos];
}
}
}