规定输入的字符串中只包含字母和 * 号。编写函数 fun ,其功能是:删除字符串中所有的 * 号。编写函数时,不得使用 C 语言提供的字符串函数。 例如: 输入:****A*BC*DEF*G*******; 输出:ABCDEFG
时间: 2023-07-01 17:26:29 浏览: 97
好的,以下是删除字符串中所有 * 号的代码实现:
```c
#include <stdio.h>
void fun(char *str) {
int len = 0;
while (str[len] != '\0') { // 计算字符串长度
len++;
}
int i = 0, j = 0;
for (i = 0; i < len; i++) {
if (str[i] != '*') { // 如果不是 * 号,就将其复制到新的字符串中
str[j] = str[i];
j++;
}
}
str[j] = '\0'; // 在新字符串的结尾添加 '\0',表示字符串的结束
}
int main() {
char str[] = "****A*BC*DEF*G*******";
printf("原字符串:%s\n", str);
fun(str);
printf("删除 * 号后的字符串:%s\n", str);
return 0;
}
```
输出结果为:
```
原字符串:****A*BC*DEF*G*******
删除 * 号后的字符串:ABCDEFG
```
这个函数的实现思路比较简单,就是遍历字符串中的每个字符,如果不是 * 号,则将其复制到新的字符串中,最后将新字符串的结尾设置为 '\0'。
相关问题
假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:删除字符串中所有*号。在编写函数时,不得使用c语言提供的字符串函数。
### 回答1:
可以使用循环遍历字符串中的每个字符,如果字符不是*号,则将其加入一个新的字符串中,最终返回这个新的字符串即可。具体实现可以参考以下代码:
```c
void fun(char *str) {
int i, j;
for (i = , j = ; str[i] != '\'; i++) {
if (str[i] != '*') {
str[j++] = str[i];
}
}
str[j] = '\'; // 将新字符串末尾加上结束符
}
```
调用该函数时,传入的参数为需要删除*号的字符串,函数会直接修改该字符串。例如:
```c
char str[] = "a*b*c*d";
fun(str);
printf("%s\n", str); // 输出:abcd
```
### 回答2:
思路:
遍历字符串,每遇到一个*号就将后面的所有字符向前移一位,直到将*号移动到末尾。如果后面没有字符了就直接将*号删除,继续遍历下一个字符。
代码如下:
```python
def fun(s):
i = 0
n = len(s)
while i < n:
if s[i] == '*':
j = i + 1
while j < n and s[j] == '*':
j += 1
if j == n:
s = s[:i]
else:
s = s[:i] + s[j:]
n = len(s)
else:
i += 1
return s
```
使用方法:
```python
s = "ab*c*d***ef***gh***"
print(fun(s))
```
输出结果:
```
abcdefgh
```
时间复杂度为 O(n^2),空间复杂度为 O(1)。
### 回答3:
题目要求在一个字符串中删除所有的星号,我们可以通过遍历字符串的每一个字符找到星号并删除它。但在删除字符时需要注意数组下标的变化。我们可以用一个变量来记录删除星号后的新长度,再用一个循环将字符串前新长度的部分赋值给原字符串,即可完成删除星号的操作。
以下是该题的示例代码:
```python
def fun(s):
new_len = 0
for i in range(len(s)):
if s[i] != '*':
s[new_len] = s[i]
new_len += 1
s[new_len:] = [] # 将多余部分截断
return s
```
该代码首先定义变量`new_len`来表示新字符串的长度,初始化为0。然后遍历原字符串`s`的每一个字符,如果不是星号就将该字符赋值给新字符串对应位置,并将新长度加1。最后将原字符串多余的部分截取掉,返回删除星号后的新字符串。
需要注意的是,字符串在Python中是不可变类型,因此我们需要将字符串转换为列表来进行删除操作。另外,此处的操作是直接修改原字符串的值,所以需要在调用函数时传入可变对象。如果不希望直接修改原字符串,可以在函数内新建一个列表并返回。
假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:删除字符串中所有的*号。在编写函数时,不得使用c语言提供的字符串函数。
可以使用循环遍历字符串中的每个字符,如果不是*号就将其加入一个新的字符串中,最后返回新的字符串即可。具体实现可以参考以下代码:
```c
void fun(char *str) {
int len = strlen(str);
char new_str[len+1]; // 新字符串,长度为原字符串长度加1,用于存储删除*号后的结果
int j = ; // 新字符串的下标
for (int i = ; i < len; i++) {
if (str[i] != '*') {
new_str[j++] = str[i]; // 将非*号字符加入新字符串中
}
}
new_str[j] = '\'; // 在新字符串末尾添加结束符
strcpy(str, new_str); // 将新字符串复制回原字符串中
}
```
使用时,可以先定义一个字符串数组,然后调用fun函数进行删除*号操作,示例如下:
```c
int main() {
char str[] = "a*b*c*d*e*f*g*h*i*j*k*l*m*n*o*p*q*r*s*t*u*v*w*x*y*z";
fun(str);
printf("%s\n", str); // 输出结果为:abcdefghijklmnopqrstuvwxyz
return ;
}
```
阅读全文