欢迎访问https://blog.csdn.net/lxt_Lucia~~
宇宙第一小仙女\(^o^)/~~萌量爆表求带飞=≡Σ((( つ^o^)つ~ dalao们点个关注呗~~
上次做日历那个题( Months and Years ( CodeForces - 899B ) )的时候,看到了a.find(b) 的用法,就以为不存在就返回的是 -1,结果昨天TD讲课才知道那里的 -1 并不是 “ -1 ”。查了下资料,今天详细介绍一下。。。。
std::string 的方法 find,返回值类型是std::string::size_type, 对应的是查找对象在字符串中的位置(从0开始),
如果未查找到,该返回值是一个很大的数据(4294967295),判断时与 std::string::npos 进行对比。
std::string str("abcdefg");
std::string::size_type pos = str.find("abc");
if (pos != std::string::npos)
{
cout << "Not find" << endl;
}
或
std::string str("abcdefg");
if (str.find("abc") != std::string::npos)
{
cout << "Not find" << endl;
}
很多同学由于经常使用 CString 的缘故,喜欢这样写:
扫描二维码关注公众号,回复:
2555676 查看本文章
std::string str("abcdefg");
int pos = str.find("abc");
if (pos < 0)
{
cout << "Not find" << endl;
}
这样写理论上也是可以的,因为 size_type 相当于 unsigned int类型,最大值4294967295强制转换为int型,就是-1
但下面的写法是错误的:
std::string str("abcdefg");
if (str.find("abc") < 0) //错误,应该写成 != std::string::npos
{
cout << "Not find" << endl;
}
最后,建议使用size_type,这样可以适应不同的平台。因为int 类型的大小会根据不同平台而不同。
拓展:
s.find(s2) 第一次出现的位置
s.rfind 最后一次出现的位置
s.find_first_of(s2) 任何一个字符第一次出现的位置
s.find_last_of 任何一个字符最后一次出现的位置
s.find_first_not_of(s2) 第一个不在s2中的字符所在位置
s.find_last_not_of(s2) 最后一个不在s2中的字符所在位置