C字符串排序

排序算法一般都是针对于数字进行排序,那char类型是否能排序呢?
试一下。

#include<stdio.h>

#include <stdlib.h>

void compare(char str[100],int length)

{

    int change=5;

    for(int i=0;i<length;i++)

    {

        for(int j=0;j<length;j++)

        {

            //if(str[i]==str[j])

            //{

            //str[i]='\0';

            //continue;

            //}

            if(str[i]>str[j])

            {

            change=str[j];

            str[j]=str[i];

            str[i]=change;

            }

        }

    }

}



void main()

{

    char a[]="fherweufashjewadfa";

    char b[]="uiorewgfagipobagbi";

    compare(a,sizeof(a));

    compare(b,sizeof(a));

    printf("%s\n",a);

    printf("%s\n",b);

    int d=0;

    scanf("%d",d);

}

排序结果是从大到小排序,而且中间变量也是可以用int类型的,然后进行比较,但是引发了一个问题,我想从小到大排序,然后输出,

#include<stdio.h>

#include <stdlib.h>

void compare(char str[100],int length)

{

    int change=5;

    for(int i=0;i<length;i++)

    {

        for(int j=0;j<length;j++)

        {

            //if(str[i]==str[j])

            //{

            //str[i]='\0';

            //continue;

            //}

            if(str[i]<str[j])

            {

            change=str[j];

            str[j]=str[i];

            str[i]=change;

            }

        }

    }

}



void main()

{

    char a[]="fherweufashjewadfa";

    char b[]="uiorewgfagipobagbi";

    compare(a,sizeof(a));

    compare(b,sizeof(a));

    printf("%s\n",a);

    printf("%s\n",b);

    int d=0;

    scanf("%d",d);

}

空的,荡漾了,为什么呢?

跟踪一下。

先看看参数void compare(char str[100],int length)一个数组+一个数组的长度,
参数应该不会有什么问题,
然后到最后,'\0'竟然也进入循环,而且一直循环,然后悲剧了,全部替换成了'\0',也就字符串全部没有了。

//if(str[i]==str[j])

            //{

            //str[i]='\0';

            //continue;

            //}

这段注释的代码是可以去除重复元素,我这个程序原本目的是,为了拼接两个字符串,拼接后要从大到小排序。

而且 还有个很蛋疼的事情,当你要从小到大排序时候,你还不能用这种方式进行排除,荡漾了

你可能感兴趣的:(字符串)