64,654
社区成员
发帖
与我相关
我的任务
分享
bool space(char c)
{
return isspace(c);
}
bool non_space(char c)
{
return !isspace(c);
}
vector<string> split(const string& str)
{
typedef string::const_iterator iter;
vector<string> ret;
iter i=str.begin();
while(i!=str.end())
{
i=find_if(i,str.end(),non_space);
iter j=find_if(i,str.end(),space);
if(i!=str.end())
ret.push_back(string(i,j));
i=j;
}
return ret;
}
直接先用一个字符串向量保存所有结果,然后遍历字符串向量#include <stdio.h>
char s[]="123 ab 4";
char *p;
int v,n,k;
void main() {
p=s;
while (1) {
k=sscanf(p,"%d%n",&v,&n);
printf("k,v,n=%d,%d,%d\n",k,v,n);
if (1==k) {
p+=n;
} else if (0==k) {
printf("skip char[%c]\n",p[0]);
p++;
} else {//EOF==k
break;
}
}
printf("End.\n");
}
//k,v,n=1,123,3
//k,v,n=0,123,3
//skip char[ ]
//k,v,n=0,123,3
//skip char[a]
//k,v,n=0,123,3
//skip char[b]
//k,v,n=1,4,2
//k,v,n=-1,4,2
//End.