// 0 1 2 3 4 5 6 7
// 注意:二进制转十进制parseInt(n, 2)
// 注意:这里使用toString(2)转化为二进制,比如1得到'1',但我们需要的是'0001,所以需要特殊处理
// 注意:除了a-fA-F0-9其他的字母不做转化处理

let str = readline().split(' ').join('')

print(fn(str))

function fn(str) {
    let s = '', odd = [], even = [], res = ''
    for(let i=0; i<str.length; i++) {
        if(i%2==0)even.push(str[i])
        else odd.push(str[i])
    }
    odd.sort()
    even.sort()
    for(let i=0; i<str.length; i++) {
        if(i%2==0)s+=even[i/2]
        else s+=odd[(i-1)/2]
    }
    for(let i=0; i<s.length; i++) {
        res += change(s[i])
    }
    return res
}

function change(s) {
    if(/[^a-fA-F0-9]/.test(s))return s
    let n1 = parseInt(s, 16)
    let n2 = handle(n1)
    let n3 = parseInt(n2, 2).toString(16).toUpperCase()
    return n3
}

function handle(n) {
    let a = n.toString(2).split('')
    while(a.length<4) {
       a.unshift('0') 
    }
    return a.reverse().join('')
}