c语言编写一个字符串整理函数void squeeze( char *str1,char *str2),该函数将str1字符串中所有在字符串str2中出现字符删除掉
时间: 2024-02-15 08:02:03 浏览: 34
好的,我来帮您编写这个函数。
函数定义如下:
```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(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中出现的字符删除。
请用c语言编写一个Squeeze函数,它的功能是删除字符串s中所出现的与变量c相同的字符。
好的,这是一个简单的C语言实现:
```c
void squeeze(char s[], int c) {
int i, j;
for (i = j = 0; s[i] != '\0'; i++) {
if (s[i] != c) {
s[j++] = s[i];
}
}
s[j] = '\0';
}
```
这个函数的参数是一个字符数组s和一个整型变量c。它会遍历字符数组s中的每一个字符,如果字符不等于变量c,就把它加入到一个新的字符数组中。最后,把新的字符数组拷贝回原来的字符数组s中。这样,所有与变量c相同的字符就被删除了。
注意,这个函数修改了原来的字符数组s,因此调用之前需要备份原来的字符数组。