1, 字符串的分割算法(标准库版)
void split(const string& s,char c,vector& v)
{
string::size_type i = 0;
string::size_type j = s.find(c);
while (j != string::npos)
{
v.push_back(s.substr(i,j-i));
i = ++j;
j = s.find(c,j);
if (j == string::npos)
v.push_back(s.substr(i,s.length()) );
}
}
template
void split(basic_string& s,T c,vector >& v)
{
typename basic_string::size_type i = 0;
typename basic_string::size_type j = s.find(c);
while (j != basic_string::npos)
{
v.push_back(s.substr(i,j-i));
i = ++j;
j = s.find(c,j);
if (j == basic_string::npos)
{
v.push_back(s.substr(i,s.length()) );
}
}
}
2,字符串的分割算法(boost库实现)
int main()
{
string _str = "I|am|a|bad|boy";
list myList;
split(myList,_str,is_any_of("|")); // 这里用到了boost组库的方法:split.
list::iterator p;
for (p = myList.begin(); p != myList.end(); ++p)
{
cout << *p << " ";
}
cout << endl;
/***********************************************/
return 0;
}