免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5022 | 回复: 5
打印 上一主题 下一主题

[函数] 问一个STL的equal_range()函数的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-07-06 14:03 |只看该作者 |倒序浏览
此函数的功能不用说了,但是我怎么才能知道这个函数返回有结果?
pair<string::iterator,string::iterator>;Result;
string s = "qwertyupiasfkjnckqjq" ; //假设是这个值
Result = equal_range(s.begin(), s.end(), temp) //查找某一字符是否有两次出现

这个Result怎么判断是成功还是未成功呢

论坛徽章:
0
2 [报告]
发表于 2004-07-06 14:37 |只看该作者

问一个STL的equal_range()函数的问题

found = ( result.first != result.second );

论坛徽章:
0
3 [报告]
发表于 2004-07-06 15:00 |只看该作者

问一个STL的equal_range()函数的问题

这种方法不对吧?
if(result.first != result.second )
{...} result.first 和result.second 本来就不等吧

论坛徽章:
0
4 [报告]
发表于 2004-07-06 15:19 |只看该作者

问一个STL的equal_range()函数的问题

首先,equal_range要求它所作用的range是排序过的。
其次,如果你找不到,就应该是first==end。

论坛徽章:
0
5 [报告]
发表于 2004-07-06 15:45 |只看该作者

问一个STL的equal_range()函数的问题

找某一字符出现几次,为什么不用 count()?何况result.first != result.second并不能说明有几个相同的字符,还要再加判断。如果是练习 equal_range(),那倒无话可说。

论坛徽章:
0
6 [报告]
发表于 2004-07-06 16:17 |只看该作者

问一个STL的equal_range()函数的问题

唉,我居然看错了,我以为他要的结果是如果找不到,所以才有那个found :p
他就算练习,也要先排序。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP