gpt4 book ai didi

c - 从C中的字符串中过滤出一个字符

转载 作者:太空宇宙 更新时间:2023-11-04 08:16:07 25 4
gpt4 key购买 nike

所以下面是一个函数,它应该从字符串中过滤掉给定的字符 ch,并将过滤后的版本放入结果中。底部的 puts 语句最终输出与原始字符串相同的字符串,而不管过滤后的字符如何,结果最终为空。

void filter_ch_index(char string[], char result[], char ch) {
result[0] = NUL ; // placeholder
int i;
for(i = 0; i < strlen(string); i++)
{
if(string[i] != ch)
{
result[i] = string[i];
}
}
puts(result);
}

最佳答案

其中一个问题是您的复制逻辑。

当字符不同时,您不会将其复制到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起始地址的备份。当当前 a 字符不是 \0 时,while 循环将继续(您可以将其读作 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 ] $

关于c - 从C中的字符串中过滤出一个字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35732029/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com