迭代器

  1. 构成迭代器的范围有何限制

    迭代器的范围未左闭右开的范围, 及end() 指向是最后一个元素的后一个元素

    我们可以通过递增begin()来到达end(), 若两个相等表示容器未空, 指向首元素,

  2. 编写函数, 通过一组迭代器找到范围里面你的某个值, 如果没有找到处理返回值的情况, 如果找到了返回迭代器

#include <iostream>
#include <vector>

typedef std::vector<int> it_int;

it_int& Check(it_int& Begin,it_int& End,int date)
{
    while(Begin != End)
    {
        if(*Begin == date) return Begin;
        ++Begin;
    }
    if(Begin == End) throw 1;	
    else throw 2;
}
int main()
{
    std::vector<int> vec_int;
    int temp = 0;
    
    while(std::cin >> temp)
    {
        vec_int.push_back(temp);
    }
    
    it_int rbegin = vec_int.begin();	
    it_int rend = vec_int.end();
    
    try{
        
        it_int it_vec = Check(rbegin,rend,6);
    }
    catch(int exp)
    {
       	switch (exp)
        {
            case 1: 
                std::cout <<"没有查找到数据"<<std::endl;
                break;
            case 2:
                st::cout << "输入迭代器范围错误" <<std::endl;
                break;
        }
    }
    std::cout <<"已查找到数据返回值为迭代器的引用"<<std::endl;
    
    return 0;
}

/*
	本题错误点在上方第一次写成了返回局部迭代器, 没有加上迭代器的引用所以系统警告
	因为要处理未找到给定值的情况, 那么可以用throw抛出异常, 在主程序里面检查异常的错误报告从而判断是那种错误
*/
  1. 下列程序的错误

    list<int> list1;
    list<int>::iterator it_be = list1.begin(), it_end = list1.end();
    while(it_end > it_begin)/*....*/
        
        
    /*
    	上述的主要错误为list容器不支持大与小与号操作, 支持的只有string or vector or queue支持除了!=和==之外的关系运算
    
    */
    
  2. 为了索引intvector中的元素应该使用什么类型

    使用std::vector<int>::size_type vec_index 来用下标表示

  3. 为了读取list<string>中的元素应该用什么类型, 如果写入list, 又该用什么类型

    使用std::list<std::string>::const_iterator it_list; 进行读取

    使用std::list<std::string>::iterator it_list2;对容器内数据改变

  4. 编写一个程序将list<const char*> 数据赋值到vector<string>

    #include <string>
    #include <vector>
    #include <list>
    #include <iostream>
    
    
    int main()
    {
        std::list<const char*> ls_ch(5,"hello");
        std::vector<std::string> vec_str(ls_ch.begin(),ls_ch.end());
        
        std::vector<std::string>::const_iterator it_vec = vec_str.begin();
        
        while(it_vec != vec_str.end())
        {
            std::cout<<*it_vec <<std::endl;
            ++it_vec;
        }
         
        return 0;
    }
    
  5. 编写程序判断vector<int>list<int>是否相等

    #include <iostream>
    #include <string>
    #include <list>
    
    int main()
    {
        std::vector<int> a(10,1);
        std::list<int> b(10,1);
        
        std::vector<int>::const_iterator it_vec = a.begin();
        std::list<int>const_iterator it_ls = b.begin();
        
        while(it_ls != b.end() && it_vec != a.end())
        {
            static int i = 0;
            if(*it_vec == *it_ls)
            {	
                ++i;
                std::cout << "第" << i << "个元素相等"<<std::endl;
            }
            ++it_vec,++it_ls;
        }
        
        
        return 0;
    }
    
  6. 假定两个容器, 下面比较有何限制

    if(c1 < c2)
    //两个容器的类型一致, 如果两个是类类型, 那么此时类应该也包含了比较运算符
    
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值