zoukankan      html  css  js  c++  java
  • 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;
                //}

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

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

  • 相关阅读:
    LInux 安装 MySQL
    JS BUG 传递数字过大,数据值会变化
    tabs 标签样式
    【异常】IOException parsing XML document from class path resource [xxx.xml]
    云服务器启动tomcat巨慢,很慢
    Linux修改/etc/profile配置错误command is not found自救方法
    linux 安装 vsftpd服务
    为什么说 Vue 的响应式更新比 React 快
    在idea中使用git拉去最新代码并merge到本地代码中
    解决重新打开一个项目,idea需要重新配置maven的问题
  • 原文地址:https://www.cnblogs.com/fish124423/p/2616696.html
Copyright © 2011-2022 走看看