| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2257 人关注过本帖
标题:C++的list怎么寻找中间的迭代器
只看楼主 加入收藏
chy9003
Rank: 2
等 级:论坛游民
帖 子:5
专家分:24
注 册:2012-7-27
结帖率:100%
收藏
已结贴  问题点数:2 回复次数:6 
C++的list怎么寻找中间的迭代器
C++的list怎么寻找中间的迭代器
除了
程序代码:
list<int>::iterator mid(list<int>::iterator beg, list<int>::iterator end){
    while(beg!=end){
        end--;
        if(beg==end)
            return beg;
        beg++;
    }
    if(beg==end)
        return beg;
}
以外还有其他方法吗
搜索更多相关主题的帖子: 其他 
2012-07-31 17:01
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:0 
list<int>::iterator mid(list<int>::iterator beg, list<int>::iterator end){
    return beg + (end - beg)/2;
}

My life is brilliant
2012-07-31 17:42
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:1 
首先,你的代码逻辑就是错误的;错了逻辑错误,其他也没有什么正确的地方

程序代码:
std::list<int>::iterator mid( std::list<int>::iterator beg, std::list<int>::iterator end )
{
    std::list<int>::difference_type dif = distance( beg, end );
    std::advance( beg, dif/2 );
    return beg;
}

const_iterator的也一样

2012-08-01 08:47
chy9003
Rank: 2
等 级:论坛游民
帖 子:5
专家分:24
注 册:2012-7-27
收藏
得分:0 
回复 3楼 rjsp
额。。能不能说明下我的逻辑错误在哪啊
我觉得没错啊。。。
2012-08-01 09:30
chy9003
Rank: 2
等 级:论坛游民
帖 子:5
专家分:24
注 册:2012-7-27
收藏
得分:0 
回复 2楼 lz1091914999
2L的代码编译报错了
2012-08-01 09:50
hepper
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2012-8-1
收藏
得分:0 
回复 5楼 chy9003
list迭代器不支持算术运算吧。。
2012-08-01 13:42
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
收藏
得分:1 
楼主如果愿意自己用 while 找也行。用 dictance 和 advance 其实也是遍历链表,不过好处是代码比较清楚。
2012-08-01 23:46
快速回复:C++的list怎么寻找中间的迭代器
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015163 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved