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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值