#include<bits/stdc++.h>
using namespace std;
int main()
{
char a[16]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
char b[10];
int k=0,i;
int n;
scanf("%d",&n);
if(n==0)
printf("0");
else
{
while(n)
{
b[k++]=a[n%16];
n=n/16;
}
for(i=k-1;i>=0;i--)
printf("%c",b[i]);
}
}
十进制转十六进制直接打表会快很多,对应的再存起来就可。