import java.util.ArrayList;
import java.util.Scanner;
/*
 * 题目描述:
 * 大家都知道,数据在计算机里中存储是以二进制的形式存储的。
 * 有一天,小明学了C语言之后,他想知道一个类型为unsigned int 类型的数字,存储在计算机中的二进制串是什么样子的。
 * 你能帮帮小明吗?并且,小明不想要二进制串中前面的没有意义的0串,即要去掉前导0。
 * 输入:
 * 第一行,一个数字T(T<=1000),表示下面要求的数字的个数。
 * 接下来有T行,每行有一个数字n(0<=n<=10^8),表示要求的二进制串。
 * 输出:
 * 输出共T行。每行输出求得的二进制串。
 * 样例输入:
 * 5
 * 23
 * 535
 * 2624
 * 56275
 * 989835
 * 样例输出:
 * 10111
 * 1000010111
 * 101001000000
 * 1101101111010011
 * 11110001101010001011
 */
public class q1473 {
	  public static void main(String[] args) {
		
		    Scanner scanner = new Scanner(System.in);
		    int T = scanner.nextInt();
		    int[] pre = new int[T];
		    for(int m=0; m<T; m++) {
			      pre[m] = scanner.nextInt();
		    }
		
		    for(int m=0; m<T; m++) {
			
			      int n = pre[m];
			      ArrayList<Integer> a = new ArrayList<Integer>();
			      
      // 考虑输入整数为0的情况
			      if(n == 0) {
				        System.out.println("0");
				        continue;
			      }
			      else {
				        while(n!=0) {
					
					          a.add(n%2);
					          n = n / 2;
	
				        }
				
				        Integer target[] = new Integer[a.size()];
				
				        target = a.toArray(target);
				
				        for(int i=target.length-1; i>=0; i--) {
					          System.out.print(target[i]);
				        }
				        System.out.println();
			      }
		    }
		
		    scanner.close();
}
}
 
                    
                 
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号