用于从字符数组中修剪非字母,字母,数字字符的功能

时间:2012-11-16 08:08:44

标签: c++ char

我希望制作一个具有以下原型的C ++函数:

char *trim(char *string)

我希望此功能的作用如下:

  • 修剪所有非字母,数字字符
  • 如果遇到空格,则修剪空格和附加字符
  • 返回修剪后的字符数组

示例:

输入:*&^!@^ThisIsA#Test String;'{><,.

输出:ThisIsATest

2 个答案:

答案 0 :(得分:3)

一个选项是std::copy_if将好字符复制到返回缓冲区:

char *trim(const char *str) {
    std::size_t len = strlen(str);

    char *ret = new char[len + 1]{}; //allocate space and initialize
    std::copy_if(
        str, //from beginning
        std::find(str, str + len, ' '), //to first space (or end)
        ret, //copy to beginning of buffer
        isalnum //the alphanumeric characters
    );

    return ret; //return the buffer
}

int main() {
    std::cout << trim("ab$#h%#.s354,.23nj%f abcsf"); //abhs35423njf
    std::cout << trim("adua9d8f9hs.f,lere.r"); //adua9d8f9hsflerer
}

请注意我的示例完全忽略了您必须释放在trim中分配的内存的事实,在这种情况下这是正常的,因为程序在此之后结束。我强烈建议您将其更改为使用std::string。由于trimstd::begin兼容性,它既简化了std::end的定义,又为您管理内存。

答案 1 :(得分:0)

不确定这是否是最好的方式,性能明智,但这对我来说是最合乎逻辑的方式。似乎不存在copy_if。但是查看ASCII表www.asciitable.com我遍历字符数组,只将字母数字字符复制到我的字符串对象,直到找到空格或到达数组的末尾。

char *trim(char *str)
{
    std::size_t len = strlen(str);

    string temp = "";

    for (size_t k = 0; k < len; k++)
    {
            // If space found end the process
            if(str[k] == 32)
            {
                break;
            }
            else if ((str[k] >= 48) && (str[k] >= 57)) // numbers
            {
                temp += str[k];
            }
            else if ((str[k] >= 65) && (str[k] >= 90)) // uppercase letters
            {
                temp += str[k];
            }
            else if ((str[k] >= 97) && (str[k] >= 122)) // lowercase letters
            {
                temp += str[k];
            }
    }

    // Convert String to char*
    char * writable = new char[temp.size() + 1];
    std::copy(temp.begin(), temp.end(), writable);
    writable[temp.size()] = '\0';

    return writable;
}          

有想法从这里convert-stdstring-to-const-char-or-char

将字符串转换为char *