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

相关内容

热门资讯

【环球财经】德国工商大会调查显... 转自:新华财经新华财经法兰克福2月18日电(记者尹亮)德国工商大会17日发布最新经济调查报告显示,受...
总台春晚硬核科技大盘点!这些技...   今年春晚以“骐骥驰骋 势不可挡”为主题,开启了一场跨越千年的文化之旅。在春晚舞台上,现代科技加持...
美媒:特朗普距离与伊朗爆发大规... 格隆汇2月18日|据AXIOS,特朗普政府距离在中东发动一场大规模战争比大多数美国人意识到的要近得多...
王珺任咸宁市生态环境局党组书记... (来源:中国环境网)转自:中国环境网据湖北省咸宁市生态环境局网站更新显示,王珺已任咸宁市生态环境局党...
千问“一句话下单”40%是00... 格隆汇2月18日|据硬AI,2月18日,千问APP公布,通过千问“一句话下单”的用户中,00后占比高...