算法问题求解,程序优化

三个整数分别为 A,B,CA,B,C。这三个数字不会按照这样的顺序给你,但它们始终满足条件:A < B 输入
1 5 3
ABC
输出
1 3 5
输入
6 4 2
CAB
输出
6 2 4
用C语言写的代码,这里面哪里有问题?代码输入数字后就停止运行了,如果有更好的程序请分享一下,求解答!谢谢!

#include
#include
int main()
{
    int x[3]={0};
    char X[4]={0};
    int i=0,t=0;
    for(i=0;i<3;i++)
    {
        scanf("%d",&x[i]);
    }
        gets(X);
    if(x[0]>x[1])
    {
        t=x[0];
        x[0]=x[1];
        x[1]=t;
    }
    if(x[0]>x[2])
    {
        t=x[0];
        x[0]=x[2];
        x[2]=t;
    }
    if(x[1]>x[2])
    {
        t=x[1];
        x[1]=x[2];
        x[2]=t;
    }
    if(strcmp(X,"ABC")==0)
    {
        for(i=0;i<3;i++)
        {
            printf("%d ",x[i]);
        }
    }
    else if(strcmp(X,"CBA")==0)
    {
        for(i=2;i>=0;i--)
        {
            printf("%d ",x[i]);
        }
    }
    if(strcmp(X,"ACB")==0)
    {
        printf("%d %d %d",x[0],x[2],x[1]);
    }
    if(strcmp(X,"BCA")==0)
    {
        printf("%d %d %d",x[1],x[2],x[0]);
    }
    if(strcmp(X,"BAC")==0)
    {
        printf("%d %d %d",x[1],x[0],x[2]);
    }
    if(strcmp(X,"CAB")==0)
    {
        printf("%d %d %d",x[2],x[0],x[1]);
    }
    return 0;
}

gets(X)是干啥用的呢?