这几天做topcoder,碰到最多的就是处理字符串,每道题首先就要处理string,才能继续。如果这块不熟,往往就要花掉很多时间,然而这些时间是可以简简单单就剩下来的。方法有很多比如,
strtok,istringstream, sscanf 等等。
这三个东西有自己适合的环境,第一个strtok用的不多,这里略过。
第二个,类istringstream 用来建立一个输入流,用内置的operate>>转换字符串的同时自动右移输入流指针。可以通过其返回值判断是否到达末尾。在输入流格式不确定的时候使用很方便。
intput:
"1 2 3 4 ..."
code:
istringstream iss;
iss.str(*it);
int temp;
while(iss>>temp)
第三个,sscanf函数。发现的时候,就感觉相见恨晚,这个家伙功能非常强大,也很面熟,在字符串格式确定的时候是很方便的实现字符串转换的方法。
input:
"000,111:222"
code:
sscanf(s.c_str(),"%d,%d:%d",&int1, &int2,&int3);
cout<<int1<<'/n'
<<int2<<'/n'
<<int2<<'/n';
output:
000
111
222