我正在尝试编写一个带字符串的函数,并将每X个字符分开:
std::vector<std::string> DIFSplitStringByNumber(std::string s, int l)
{
const char *c = s.c_str();
char buffer[l];
std::vector<std::string> entries;
entries.reserve(int(s.length() / l) + 1);
int d = 0;
for(int i = 0; i < s.length() - 1;)
{
if(d != l)
{
buffer[d] = c[i];
d++;
i++;
}
else
{
entries.push_back(std::string(buffer, l));
//Clear array
memset(buffer, 0, l);
d = 0;
}
}
return entries;
}
例如,如果我调用DIFSplitStringByNumber("hello!", 2)
,我应该得到一个包含:
[0] he
[1] ll
[2] o!
然而,它似乎只得到前两个结果(向量大小为2),当我做DIFSplitStringByNumber("hello", 2)
之类的事情时,它崩溃了,大概是因为它试图访问一个没有的数组索引存在(它需要6个字符,但只有5个字符)。有更简单的方法吗?
答案 0 :(得分:9)
算法的核心实际上归结为以下两行。
for (size_t i = 0; i < s.size(); i += l)
res.push_back(s.substr(i, l));
此外,您应该通过const引用传递字符串。
答案 1 :(得分:3)
这会将字符串拆分为一个向量。如果没有偶数个分割,它会在末尾添加额外的字符。
std::vector<std::string> Split(const std::string& str, int splitLength)
{
int NumSubstrings = str.length() / splitLength;
std::vector<std::string> ret;
for (auto i = 0; i < NumSubstrings; i++)
{
ret.push_back(str.substr(i * splitLength, splitLength));
}
// If there are leftover characters, create a shorter item at the end.
if (str.length() % splitLength != 0)
{
ret.push_back(str.substr(splitLength * NumSubstrings));
}
return ret;
}
答案 2 :(得分:2)
使用std :: string是char的集合,一个简单的实现可能是:
std::vector<std::string> DIFSplitStringByNumber(const std::string & str, int len)
{
std::vector<std::string> entries;
for(std::string::const_iterator it(str.begin()); it != str.end();)
{
int nbChar = std::min(len,(int)std::distance(it,str.end()));
entries.push_back(std::string(it,it+nbChar));
it=it+nbChar;
};
return entries;
}
答案 3 :(得分:1)
更改计算矢量大小的方式:
int size = (s.length() - 1) / l + 1;
这相当于输入字符串长度的上限除以输入长度。
BTW,int(s.length() / l)
转换是无用的,因为两个操作数都是整数。
最后,在循环中使用此大小:
for (int i=0; i<size; i++)