C语言实例_27之删除字符串中指定字符

1. 题目

删除一个字符串中的指定字母,例如:对于字符串 "aka47-k8",删除其中的 "k" 字母。

2. 实现思路

  • 思路一:遍历原字符串并新建字符串(数组)存储结果
    • 首先定义两个指针,一个用于遍历原字符串,另一个用于指向新开辟的用来存储结果的字符数组(字符串)。
    • 然后从头到尾遍历原字符串中的每一个字符,对于每个字符进行判断,如果该字符不是要删除的指定字母,就将其复制到新的字符数组中,并将结果字符串的指针后移一位;如果是要删除的指定字母,则跳过该字符,继续判断下一个字符。
    • 最后在新的字符数组末尾添加字符串结束标志'\0',使其成为一个合法的字符串。
  • 思路二:在原字符串上直接操作(双指针法)
    • 定义两个指针,一个快指针和一个慢指针,初始时都指向字符串的开头位置。
    • 快指针用于快速遍历原字符串中的字符,慢指针用于指向处理后的字符串中当前要写入字符的位置。
    • 当快指针遍历到的字符不是要删除的指定字母时,把该字符赋值给慢指针指向的位置,然后快慢指针同时往后移动一位;如果快指针遍历到的字符是要删除的指定字母,那么只移动快指针,慢指针不动,这样就相当于跳过了要删除的字符,从而实现了在原字符串基础上删除指定字母的操作,最后在慢指针位置添加字符串结束标志'\0'。

3. 实例代码

实现方式一:遍历原字符串并新建字符串(数组)存储结果

cpp 复制代码
#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "aka47-k8";
    char target = 'k';
    char result[100];  // 假设原字符串长度不会超过100,用于存储结果字符串
    int j = 0;

    for (int i = 0; i < strlen(str); i++) {
        if (str[i]!= target) {
            result[j++] = str[i];
        }
    }
    result[j] = '\0';

    printf("删除指定字母后的字符串为:%s\n", result);

    return 0;
}

实现方式二:在原字符串上直接操作(双指针法)

cpp 复制代码
#include <stdio.h>
#include <string.h>

int main() {
    char strSrc[] =  "aka47-k8";
    char str[] = "aka47-k8";
    char target = 'k';
    int slow = 0;
    int fast = 0;

    while (fast < strlen(str)) {
        if (str[fast]!= target) {
            str[slow++] = str[fast++];
        } else {
            fast++;
        }
    }
    str[slow] = '\0';
	printf("原始字符串为:%s\n", strSrc);
    printf("删除指定字母后的字符串为:%s\n", str);

    return 0;
}

4. 输出结果

相关推荐
坚持编程的菜鸟13 分钟前
LeetCode每日一题——困于环中的机器人
c语言·算法·leetcode·机器人
Aurorar0rua2 小时前
C Primer Plus Notes 09
java·c语言·算法
R-G-B3 小时前
【02】C#入门到精通——C# 变量、输入/输出、类型转换
开发语言·c#·c# 变量·c#输入/输出·c#类型转换
星河队长3 小时前
C# 软件加密方法,有使用时间限制,同时要防止拷贝
开发语言·c#
史迪奇_xxx4 小时前
10、一个简易 vector:C++ 模板与 STL
java·开发语言·c++
2301_801252224 小时前
Java中的反射
java·开发语言
Kiri霧4 小时前
Rust开发环境搭建
开发语言·后端·rust
weixin-a153003083164 小时前
[数据抓取-1]beautifulsoup
开发语言·python·beautifulsoup
我不是QI4 小时前
DES 加密算法:核心组件、加解密流程与安全特性
经验分享·算法·安全·网络安全·密码学
前端小刘哥5 小时前
新版视频直播点播EasyDSS平台,让跨团队沟通高效又顺畅
算法