编写一个程序,当在一个字符串中出现子串时就删除它。用C语言
时间: 2024-03-24 10:37:43 浏览: 34
好的,以下是一个简单的 C 语言程序,可以实现删除字符串中指定子串的功能。
```c
#include <stdio.h>
#include <string.h>
void remove_substring(char *str, char *sub) {
int len = strlen(sub);
char *p = str;
while ((p = strstr(p, sub))) {
memmove(p, p + len, strlen(p + len) + 1);
}
}
int main() {
char str[1000], sub[100];
printf("请输入原字符串:");
fgets(str, sizeof(str), stdin);
printf("请输入要删除的子串:");
fgets(sub, sizeof(sub), stdin);
remove_substring(str, sub);
printf("删除后的字符串为:%s", str);
return 0;
}
```
该程序通过使用 `strstr` 函数查找字符串中指定子串的位置,然后使用 `memmove` 函数将子串后面的字符向前移动,最终删除指定子串。
需要注意的是,由于输入的字符串可能包含换行符,因此使用 `fgets` 函数获取字符串输入,并且在输出时需要将换行符去除。
相关问题
编写一个程序输入字符串判断字符串是否是子串C语言
下面是一个简单的程序,可以输入一个字符串和一个子串,判断子串是否在字符串中出现过:
```c
#include <stdio.h>
#include <string.h>
int main() {
char str[100], substr[100];
printf("Enter a string: ");
scanf("%s", str);
printf("Enter a substring: ");
scanf("%s", substr);
if (strstr(str, substr) != NULL) {
printf("'%s' is a substring of '%s'\n", substr, str);
} else {
printf("'%s' is not a substring of '%s'\n", substr, str);
}
return 0;
}
```
该程序使用了 C 标准库中的 `strstr` 函数来查找子串是否在字符串中出现过。如果 `strstr` 函数返回值不为 `NULL`,则说明子串在字符串中出现过,否则说明子串不在字符串中出现过。
用c语言编写一个程序判断一个字符串是否为另一个字符串的子串
好的,我可以帮你解答这个问题。
首先,我们需要明确子串的定义:一个字符串中的一段连续字符构成的字符串即为该字符串的子串。
那么,我们可以通过遍历原字符串的每个字符,判断是否与子串的第一个字符相等。如果相等,则继续比较后面的字符是否也相等,如果全部相等,则说明子串在原字符串中存在。
以下是一个用 C 语言实现的判断子串的函数:
```
int isSubstr(char *str, char *sub)
{
int i, j, flag;
for (i = 0; str[i] != '\0'; i++)
{
flag = 1;
for (j = 0; sub[j] != '\0'; j++)
{
if (str[i+j] != sub[j])
{
flag = 0;
break;
}
}
if (flag == 1)
{
return i;
}
}
return -1;
}
```
这个函数会返回子串在原字符串中的起始位置,如果没有找到则返回 -1。
调用这个函数的方法如下:
```
char str[] = "Hello, World!";
char sub[] = "World";
int pos = isSubstr(str, sub);
if (pos != -1)
{
printf("'%s' is a substring of '%s', starts at position %d\n", sub, str, pos);
}
else
{
printf("'%s' is not a substring of '%s'\n", sub, str);
}
```
这样就可以判断一个字符串是否为另一个字符串的子串了。