我有一系列字符串存储在一个数组中,由空值分隔(例如 ['f', 'o', 'o', '\0', 'b', 'a', 'r' , '\0'...]),我需要将其拆分为 std::vector<std::string>
或类似的。
我可以使用 std::find
编写一个 10 行循环来执行此操作或 strlen
(事实上我只是这样做了),但我想知道是否有更简单/更优雅的方法来做到这一点,例如我忽略的一些 STL 算法,可以被诱使这样做。
这是一项相当简单的任务,如果可以应用一些巧妙的 STL 技巧使其变得更简单,我也不会感到惊讶。
有接受者吗?
最佳答案
我的两分钱:
const char* p = str;
std::vector<std::string> vector;
do {
vector.push_back(std::string(p));
p += vector.back().size() + 1;
} while ( // whatever condition applies );
关于c++ - 在 C++ 中拆分空分隔字符串序列的简单方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7243723/