c语言编写一个字符串整理函数void squeeze( char *str1,char *str2),该函数将str1字符串中所有在字符串str2中出现字符删除掉
时间: 2024-02-15 08:02:03 浏览: 165
好的,我来帮您编写这个函数。
函数定义如下:
```c
void squeeze(char *str1, char *str2);
```
函数参数说明:
- `str1`:要整理的字符串。
- `str2`:包含要删除的字符的字符串。
函数实现:
```c
#include <string.h>
void squeeze(char *str1, char *str2) {
char *p = str1; // p指向str1字符串中当前未删除的字符
int len = strlen(str2);
while (*p != '\0') {
if (strchr(str2, *p) == NULL) { // 如果当前字符不在str2中,则保留该字符
*str1++ = *p;
}
p++;
}
*str1 = '\0'; // 添加字符串结束标志
}
```
函数说明:
- `strchr(str2, *p)` 函数用于判断当前字符是否在 `str2` 字符串中,如果返回值为 `NULL`,则说明该字符不在 `str2` 中。
- `*str1++ = *p` 表示将指针 `p` 指向的字符复制到 `str1` 指向的位置,并将 `str1` 指针向后移动一位。
- 最后,别忘了在整理后的字符串末尾添加字符串结束标志 `\0`。
希望这个函数能够满足您的需求。
相关问题
编写一个字符串整理函数void squeeze(),该函数将str1字符串中所有在字符串str2中出现的字符删掉
要编写一个名为`squeeze()`的C语言函数,这个函数接受两个字符串参数`str1`和`str2`,并移除`str1`中`str2`中包含的所有字符,你可以使用`for`循环遍历`str1`中的每个字符,如果该字符不在`str2`中,则将其添加到结果字符串中。这里有一个简单的实现:
```c
#include <stdio.h>
#include <string.h>
// 创建一个新的字符串,用于存储处理后的结果
char* create_result_string(const char* str1, const char* str2) {
size_t len1 = strlen(str1);
size_t len2 = strlen(str2);
// 计算去除str2字符后str1的长度
for (size_t i = 0; i < len1; ++i) {
if (strchr(str2, str1[i]) == NULL) {
len1--;
}
}
// 动态分配新的字符串空间
char* result = malloc(len1 + 1); // 加1是因为我们要加上终止符'\0'
if (result != NULL) {
// 将str1中非str2字符复制到新字符串
for (size_t i = 0, j = 0; i < len1; ++i) {
if (strchr(str2, str1[i]) == NULL) {
result[j++] = str1[i];
}
}
result[j] = '\0'; // 结束字符串
} else {
printf("Memory allocation failed.\n");
return NULL;
}
return result;
}
// 函数声明,注意void类型
void squeeze(char* str1, const char* str2);
int main() {
char str1[] = "Hello, World!";
char str2[] = "lo";
char* result = create_result_string(str1, str2);
if (result != NULL) {
printf("Squeezed string: %s\n", result);
free(result); // 不要忘记释放内存
}
return 0;
}
// 函数定义
void squeeze(char* str1, const char* str2) {
create_result_string(str1, str2); // 在这个函数里,我们直接调用create_result_string()
}
编写一个字符串函数void squeeze(char str1[],char str2[]),该函数将str1字符串中所有在字符串str2中出现的字符删掉,如char s1[20]="THISISABOOK",s2[5]="IS",则调用函数后,s1="THABOOK"。
以下是squeeze函数的实现代码:
```c
void squeeze(char str1[], char str2[]) {
int i, j, k;
int len1 = strlen(str1);
int len2 = strlen(str2);
for (i = j = 0; i < len1; i++) {
for (k = 0; k < len2; k++) {
if (str1[i] == str2[k]) {
break;
}
}
if (k == len2) {
str1[j++] = str1[i];
}
}
str1[j] = '\0';
}
```
函数中使用了两个循环,第一个循环遍历字符串str1,并准备删除str2中包含的字符。第二个循环遍历字符串str2,检查str1中的字符是否在str2中出现。如果str1[i]等于str2[k],则跳出循环并不将该字符拷贝到新的字符串中。最终结果就是将str1中所有在str2中出现的字符删除。
阅读全文
相关推荐














