练习 2-4
都删除。
squeeze(s1, s2),将字符串 s1 中任何与字符串 s2 中字符匹配的字符
练习 2-5
编写函数 any(s1, s2),将字符串 s2 中的任一字符在字符串 s1 中第一次
出现的位置作为结果返回。 如果 s1 中不包含 s2 中的字符, 则返回-1。
(标准库函数 strpbrk具有同样的功能,但它返回的是指向该位置的指针。)
#include <stdio.h>
void squeeze(char s1[], char s2[])
{
int i = 0, j = 0, k;
for(k = 0; s2[k] != '\0'; k++){
for(; s1[i] != '\0'; i++){
if(s1[i] != s2[k])
s1[j++] = s1[i];
}
s1[j] = '\0';
i = j = 0;
}
}
int any(char s1[], char s2[])
{
int i, j;
for(i = 0; s1[1] != '\0'; i++)
for(j = 0; s2[j] != '\0'; j++)
if(s2[j] == s1[i])
return i+1;
return -1;
}
int main()
{
char s1[] = "unday!";
char s2[] = "what is the tomorrow day?";
printf("%d\n", any(s1, s2));
squeeze(s1, s2);
printf("%s\n%s\n", s1, s2);
return 0;
}