C语言学习笔记(十六)
创始人
2024-03-07 18:32:26

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;
}
______________________________________________________________

相关内容

热门资讯

省委部署开展持续深化违规吃喝问... 转自:中安在线近日,省委办公厅印发《关于巩固拓展深入贯彻中央八项规定精神学习教育成果持续深化违规吃喝...
智者勇进•接续奋进新江苏|用数... 转自:扬子晚报在城市加速转型、发展方式不断更新迭代的当下,雨花台区把“数智”作为提升城市运行效率的重...
中创智领:董事长、副总经理拟合... 转自:贝壳财经新京报贝壳财经讯 12月21日,中创智领公告称,董事长焦承尧、副总经理付奇和张海斌因个...
广深港高铁客流破纪录:3000... 12月20日,从广州南发出的G6541次列车准时抵达香港西九龙站,来自香港南元朗官立小学的近百名学生...
加科思-B(01167)附属与... 加科思-B(01167)公布,该集团的非全资附属公司北京加科思新药研发有限公司与AstraZenec...