在字符串S1中删除字符串S2中所包含的字符【转】

简介: 转自:http://www.cnblogs.com/tolimit/p/4202959.html /************************************************************************* > File Name: test.

转自:http://www.cnblogs.com/tolimit/p/4202959.html

/*************************************************************************
    > File Name: test.c
    > Author: ToLiMit
    > Mail: 348958453@qq.com 
    > Created Time: Sun 04 Jan 2015 06:20:05 PM PST
 ************************************************************************/

#include<stdio.h>

void delete_str_char (char * main_str, char * sub_str)
{
    if ((main_str == NULL) || (sub_str == NULL))
        return;

    char * sub_index = sub_str;
    char * main_index = main_str;
    char bitmap[32] = {0};
    char * str = (char *)malloc (strlen (str) + 1);
    char * index = str;
    memset (str, 0, strlen (str) + 1);

    while (*sub_index != '\0') {
        char suffix = ((*sub_index) / 8) - 1;
        char offset = (*sub_index) % 8;

        bitmap[suffix] |= (0x1 << (8 - offset));
        sub_index++;
    }

    while (*main_index != '\0') {
        char suffix = ((*main_index) / 8) - 1;
        char offset = (*main_index) % 8;

        if ((bitmap[suffix] & (0x1 << (8 - offset))) == 0) {
            *index = *main_index;
            index++;
        }
        main_index++;
    }

    *index = '\0';
    memcpy (main_str, str, strlen (str) + 1);
    free (str);
    return;
}

int main (int argc, char * argv[])
{
    char test[] = "aabcdaaaaabcaacb";

    delete_str_char (test, "bcd");
    printf ("%s\n", test);
    return 0;
}

 

【作者】 张昺华
【新浪微博】 张昺华--sky
【twitter】 @sky2030_
【facebook】 张昺华 zhangbinghua
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
目录
相关文章
|
3月前
|
存储 Java 数据处理
|
2天前
删除字符串中的除字母外的字符
【10月更文挑战第31天】删除字符串中的除字母外的字符。
10 4
|
3月前
|
Java 测试技术 API
如何检查字符串是否仅包含数字
【8月更文挑战第22天】
175 0
|
4月前
|
机器学习/深度学习 缓存 安全
Python标准库中的`str`类型有一个`translate()`方法,它用于替换字符串中的字符或字符子集。这通常与`str.maketrans()`方法一起使用,后者创建一个映射表,用于定义哪些字符应该被替换。
Python标准库中的`str`类型有一个`translate()`方法,它用于替换字符串中的字符或字符子集。这通常与`str.maketrans()`方法一起使用,后者创建一个映射表,用于定义哪些字符应该被替换。
|
6月前
|
索引 容器
06-数据容器str(字符串)-字符串的下标索引/字符串无法修改/查找字符串下标初始值/字符串的替换/字符串的分割/字符串去除前后空格/统计字符串的数量/字符串的循环遍历/对字符串进行分割
06-数据容器str(字符串)-字符串的下标索引/字符串无法修改/查找字符串下标初始值/字符串的替换/字符串的分割/字符串去除前后空格/统计字符串的数量/字符串的循环遍历/对字符串进行分割
|
11月前
|
算法 测试技术 C#
C++算法:包含三个字符串的最短字符串
C++算法:包含三个字符串的最短字符串
题目:下列给定程序中函数fun的功能是:从p所指字符串中找出ASCII码值最大的字符,将其放在第一个位置上,并将该字符前的原字符向后顺序移动。
题目:下列给定程序中函数fun的功能是:从p所指字符串中找出ASCII码值最大的字符,将其放在第一个位置上,并将该字符前的原字符向后顺序移动。
|
Shell Perl
把一个文档前五行中包含字母的行删掉,同时删除6到10行包含的所有字母
把一个文档前五行中包含字母的行删掉,同时删除6到10行包含的所有字母
112 1
|
数据安全/隐私保护 索引
labview字符串数据长度连接子字符串大小写替换删除插入日期匹配
labview字符串数据长度连接子字符串大小写替换删除插入日期匹配
246 0
|
C语言
查找某字符串出现的位置,并且输出该第一个字母所在的位
查找某字符串出现的位置,并且输出该第一个字母所在的位
135 0
查找某字符串出现的位置,并且输出该第一个字母所在的位