#include<stdio.h>
#include<cstring>
#include<iostream>
#include<math.h>
using namespace std;
int main()
{
string s1,s2;
cin >> s1;
s2 = "";
for(int i=0;i<s1.length();i++)
{
switch(s1[i])
{
case'1': s2+="01";break;
case'2': s2+="02";break;
case'3': s2+="03";break;
case'4': s2+="04";break;
case'5': s2+="05";break;
case'6': s2+="06";break;
case'7': s2+="07";break;
case'8': s2+="08";break;
case'9': s2+="09";break;
case'A': s2+="10";break;
case'B': s2+="11";break;
case'C': s2+="12";break;
case'D': s2+="13";break;
case'E': s2+="14";break;
case'F': s2+="15";break;
default:break;
}
}
long long p=0;
int m=0;
for(int j=s2.length()-1;j>=0;j-=2,m++){
long long x = pow(16,m);
/*pow函数
头文件:#include <math.h>
1.函数原型
pow() 函数用来求 x 的 y 次幂(次方),x、y及函数值都是double型 ,其原型为:
double pow(double x, double y);
2. 使用
pow()用来计算以x 为底的 y 次方值,然后将结果返回。设返回值为 ret,则 ret = xy。
*/
p += x*((s2[j]-'0')+10*(s2[j-1]-'0'));
}
cout<<p<<endl;
return 0;
}