• C语言学习笔记(十六)


    C语言学习第十六天

    2.8 自增运算符与自减运算符

    C语言提供了两个用于变量递增与递减的特殊运算符。自增运算符++使其操作数递增1,自减运算符--使其操作数递减1。例如:

        if (c == '\n')
            ++nl;

    ++与--这两个运算符特殊的地方主要表现在:它们既可以用作前缀运算符(用在变量前面,如++n),也可以用作后缀运算符(用在变量后面,如n++)。这两种情况下,其效果都是将变量n的值加1。但是它们之间有一点不同。表达式++n先将n的值递增1,然后在使用变量n的值,而表达式n++则是先使用变量n的值,然后再将n的值 递增1.也就是说,对于使用变量n的值的上下文来说,++n和n++效果时不同的。如果n的值为5,那么

        x = n++;

    执行后的结果时将x的值置为5,而

        x = ++n;

    将x的值置为6。这两条语句执行完成后,变量n的值都是6。自增与自减运算符只能作用与变量,类似于表达式(i+j)++是非法的。
    在不需要使用任何具体值,且仅需要递增变量的情况下,前缀和后缀方式的效果相同。如:

        if (c == '\n')
            nl++;

    但在某些情况下需要酌情考虑。如下函数squeeze(s, c),它删除字符串s中出现的所有字符c:

    /* squeeze函数:从字符串s中删除字符c*/
    void squeeze1(char s[], int c) {
        int i, j;

        for (i = j = 0; s[i] != '\0'; i++)
            if (s[i] != c)
                s[j++] = s[i];
        s[j] = '\0';
    }

    每当出现一个不是c的字符是,该函数把它拷贝到数组中下标为j的位置,随后才将j的值增加1,以准备处理下一个字符。其中if语句完全等价于下列语句:

        if (s[i] != c) {
            s[j] = s[i];
            j++;
        }

    在第一章编写的getline是类似结构的另外一个例子。例如:

        if (c == '\n') {
            s[i] = c;
            ++i;
        }

    可以用下面这种更简洁的形式替代:

        if (c == '\n')
            s[i++] = c;

    第三个例子。考虑标准函数strcat(s, t),它将字符串t连接到字符串s的尾部。函数strcat假定字符串s中有足够的空间保存这两个字符串连接的结果。如下:

    /* strcat函数: 将字符串t连接到字符串s的尾部;s必须有足够大的空间 */
    void strcat1(char s[], char t[]) {
        int i, j;

        i = j = 0;
        while (s[i] != '\0')    /* 判断是否为字符串s的尾部 */
            i++;
        while ((s[i++] = t[j++]) != '\0')    /* 拷贝t */
            ;
    }

    在将t中的字符逐个拷贝到s的尾部时,变量i和j使用的都是后缀运算符,从而保证在循环过程中i与j均指向下一个位置。

    练习2-4 重新编写函数squeeze(s1, s2),将字符串s1中任何与字符串s2中字符匹配的字符都删除。
    练习2-5 编写函数any(s1, s2),将字符串s2中任一字符在字符串s1中第一次出现的位置作为结果返回。如果s1中不包含s2中的字符,则返回-1.(标准库函数strpbrk具有同样的功能,但它返回的时指向该位置的指针。)

    ______________________________________________________________

    /* 练习2-4 重新编写函数squeeze(s1, s2),将字符串s1中任何与字符串s2中字符匹配的字符都删除。 */
    void squeeze2(char s1[], char s2[]) {
        int i, j, k, ins2;

        for (i = j = 0; s1[i] != '\0'; i++) {
            ins2 = 0;    // 表示这个字符是否在s2中匹配到
            for (k = 0; s2[k] != '\0'; k++)
                if(s1[i] == s2[k])
                    ins2 = 1;
            if (!ins2) // 如果没匹配到,就记录这个值
                s1[j++] = s1[i];
        }
        s1[j] = '\0';
    }
    ______________________________________________________________

    /* 练习2-5 编写函数any(s1, s2),将字符串s2中任一字符在字符串s1中第一次出现的位置作为结果返回。如果s1中不包含s2中的字符,则返回-1.(标准库函数strpbrk具有同样的功能,但它返回的时指向该位置的指针。)*/
    int any(char s1[], char s2[]) {
        int i, j;

        for(i = 0; s1[i] != '\0'; i++ )
            for(j = 0; s2[j] != '\0'; j++)
                if(s1[i] == s2[j])
                    return i;
        return -1;
    }
    ______________________________________________________________

  • 相关阅读:
    ES 日期格式处理
    互联网大厂知识点整理
    maven的安装即案例
    Qml中的那些坑(三)---MouseArea上的ListView滚轮事件穿透
    Laravel 博客开发|管理后台里程碑管理
    【无标题】
    taskAffinity详解
    Super Vlan理论讲解
    ETHERNET IP站转MODBUS RTU协议网
    常用CSS样式属性
  • 原文地址:https://blog.csdn.net/u014360189/article/details/128124274