我希望制作一个具有以下原型的C ++函数:
char *trim(char *string)
我希望此功能的作用如下:
示例:
输入:*&^!@^ThisIsA#Test String;'{><,.
输出:ThisIsATest
答案 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
。由于trim
和std::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;
}
将字符串转换为char *