重新编写函数squeeze(s1,s2),将字符串s1中任何与字符串s2中字符匹配的字符都删除
重新编写函数squeeze(s1,s2),将字符串s1中任何与字符串s2中字符匹配的字符都删除void squeeze(char s1[], char s2[])
{
int i, j, k;
for (i = k = 0; s1 != '\0'; i++)
{
for (j = 0; s2 != '\0' && s2 != s1; j++)
{
;
}
if (s2 == '\0')
{
s1 = s1;
}
}
s1 = '\0';
}
为什么会有if(s2=='\0')这个条件啊
完全看不懂这个代码是怎么实现题目要求的,求大神讲解 s1[]中如果没有与是s2[]中相同的s2[]最后就等于‘\0’ 就把这个字符存入s1中然后k++ void squeeze(char s1[], char s2[])
{
int i, j, k;
for (i = k = 0; s1 != '\0'; i++)
{
for (j = 0; s2 != '\0' && s2 != s1; j++) //当s2='\0'或者s2==s1的时候才跳出循环
{
;
}
if (s2 == '\0')//判断跳出循环后s2是否等于'\0',也就是判断是否是遍历完s2[];若s2=='0',表示在s2[]中没找到和s1相同的字符;若s2!='0'则表示找到s2==s1,跳出循环。
{
s1 = s1;
}
}
s1 = '\0';//最后加个结束符
}
页:
[1]