• 删除字符串中的空格


    咋一看觉得很简单,其实自己做也花了些时间。同样,仅仅是删除空格并输出的话很简单。而将空格删除再存储字符串就没那么简单了。

    首先,贴上删除空格并输出字符串的程序如下,比较简单,不多做介绍。

    /**************删除空格并打印***************/
    void print_del_spac(char *p1)
    {
        while(*p1 != '')
        {
            if(*p1 != ' ')
                putchar(*p1);
            p1++;
        }
        putchar('
    ');
    }

    其次,贴上删除空格并存储新的字符串的程序如下:

    /***************删除空格并储存**************/
    void
    delete_space(char *p) { int i,space_count=0; int len = strlen(p); for(i=0; i<len; i++) { if(*(p+i) == ' ') //空格计数 space_count++; if (space_count != 0) //空格出现后后面的字符如何处置 *(p+i+1-space_count) = *(p+i+1); //这个很关键的一个公式,一个字符前面出现了几个空格就要往前移动几个空格,不容易想到啊,我还是很有灵感地 } for(; space_count>0; space_count--) //字符串的最后几位赋值为空格 p[len-space_count] = ' '; }

    最后,分析一下答案给出的解决方案

    /*************答案给出的解决方案************/
    void delspace(char *p1)
    {
        char *p2;
        while (*p1 != '')
        {
            if (*p1 == ' ')
            {
                p2 = p1;
                while(*p2 != '')  //遇到一个空格,就把后面的字符全往前移动一位,所以要循环“空格个数”次才能完全移位成功
                {
                    *p2 = *(p2+1);  //用了另一个指针p2,不打乱p1的挨个按顺序检查
                    p2++;
                }
                p1--; //抵消下面的p1++
            }
            p1++;
        }
    }

    这个方法思路比较清晰,亲测可行,但是字符串很长且空格很多的时候,循环的次数就比较多了。不如我的方法快捷,一次就搞定。但是我的方法在实际调试过程中,自己也容易蒙。调试中也有了一点心得,对于字符串整体要改动的话,最好在监视窗口监视整个字符串(即指向字符串的指针)即可,这样就能看到整体字符串的变化了;否则一个个看字符的变化,自己也记不住,而且容易搞乱搞混。

  • 相关阅读:
    T-SQL部分函数(转)
    sql server中触发器
    sql server中查询结果集顺序问题
    sql server中的TimeStamp时间戳与UniqueIdentifier数据类型
    SQL
    SQL表的最基本操作练习
    增删改查 T-SQL最基本操作
    SQL表的默认常用数据类型
    算法训练 P1102
    算法训练 最短路
  • 原文地址:https://www.cnblogs.com/TomLily/p/6007115.html
Copyright © 2020-2023  润新知