其中一个问题是您的复制逻辑。
当字符不同时,您不会将其复制到result
,,但您仍然增量i
。在result
字符串中留下孔。为了解决这个问题,你可以使用指针(引用和增量)。
我看到的另一个问题是您如何调用该函数。你为两者分配了足够的内存空间吗?
我会把非常不安全的函数的实现来展示你如何做到这一点。您应该修改函数以考虑字符串大小。
#include <stdio.h>
void filter(char *a, char *b, char c)
{
char *aux = b;
while(*a) {
if(*a != c) *b++ = *a;
a++;
}
*b = 0x0; // thx to @PaulRoub for pointing it out
puts(aux);
}
int main(int argc, char *argv[])
{
char buffer[100];
if(argc < 3) {
printf("Usage: %s <string> <character>\n", argv[0]);
return 0;
}
filter(argv[1], buffer, argv[2][0]);
return 0;
}
在上面的代码,aux
充当的b
起始地址的备份。 while
循环将继续,而当前的a
字符不是\0
(您可以将其读取为while (*a != '\0')
)。条件也很简单。复制部分是我之前谈到的。
我们只会增加b
字符串如果我们复制一些东西,否则它的引用保持不变。该过程将继续,直到循环找到a
字符串中的\0
终止字符。
输出:
[ ~/src/test ] $ ./filter "Stack Overflow Questions" e
Stack Ovrflow Qustions
[ ~/src/test ] $ ./filter "Stack Overflow Questions" S
tack Overflow Questions
[ ~/src/test ] $ ./filter "Stack Overflow Questions" s
Stack Overflow Quetion
[ ~/src/test ] $ ./filter "aaa bbb ccc abc cba" a
bbb ccc bc cb
[ ~/src/test ] $ ./filter "aaa bbb ccc abc cba" b
aaa ccc ac ca
[ ~/src/test ] $ ./filter "aaa bbb ccc abc cba" c
aaa bbb ab ba
[ ~/src/test ] $
这清理了很多,非常感谢。 –
@PaulRoub噢,谢谢! –