#include<stdio.h>
#include<string.h>
void sort(char *str);
int comp(char a,char b);
int main(){
    char str[1000];
    while( fgets(str,1000,stdin) !=NULL ){
        sort(str);
    }
    return 0;

}
void sort(char *str){
    char strAlp[1000];//字母表
    int len=strlen(str);
    //模板
    if(len>0&&str[len-1]=='\n'){
        str[len-1]='\0';
        len--;
    }
    int lenAlp=0;
    for(int i=0;i<len;i++){
        if( ( str[i]<='Z'&&str[i]>='A' ) || ( str[i]<='z'&&str[i]>='a' ) )
            strAlp[lenAlp++]=str[i];
    }
    strAlp[lenAlp]='\0';
    //冒泡稳定排序
    for(int i=0;i<lenAlp-1;i++){
        for(int j=0;j<lenAlp-i-1;j++){
            if( comp( strAlp[j],strAlp[j+1] ) ){
                char temp=strAlp[j];
                strAlp[j]=strAlp[j+1];
                strAlp[j+1]=temp;
            }
        }
    }
    //修改
    int j=0;
    for(int i=0;i<len;i++){
        if( ( str[i]<='Z'&&str[i]>='A' ) || ( str[i]<='z'&&str[i]>='a' ) ){
            str[i]=strAlp[j++];
        }
    }
    //输出
    printf("%s\n",str);
}
int comp(char a,char b){
    if(a<='Z' && a>='A') a=a-'A'+'a';
    if(b<='Z' && b>='A') b=b-'A'+'a';
    return a>b;
}