构造 y=10^m+1,其中m是 x的位数。这种方法生成的 x*y 会将 x 的数字重复两次,确保数集是子集。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main(){
    int t; cin>>t;
    while(t--){
        ll x,y=1,xx; 
        cin>>x; xx=x;
        while(xx){
            y*=10;
            xx/=10;
        }
        cout<<y+1ll<<endl;
    }
}