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