is_thinking 2016-08-14 15:26 采纳率: 66.7%
浏览 1264
已采纳

请问vector不能这样写吗?

下面是在二维数组中的查找target, 错误提示:no viable overloaded '='

 class Solution {
public:
    bool Find(vector<vector<int> > array,int target) {
        vector<int>::iterator itrx;
        vector<int>::iterator itry;
        for(itrx=array.begin();itrx!=array.end();itrx++){ //: no viable overloaded '='
            for(itry=itrx.begin();itry!=itrx.end();itry++){
                if(itry==target){
                    return true;
                } else if(itry > target) {
                    break;
                }
            }
        }
        return false;
    }
};

谢谢

  • 写回答

6条回答 默认 最新

  • is_thinking 2016-08-15 08:16
    关注

    知道怎么修改了,以前的错误主要源于自己不知道如何访问嵌套的vector,现在下面两种方法都可以访问嵌套的vector,方便后面的人查看访问方式。

    方法一:

     class Solution {
    public:
        bool Find(std::vector<std::vector<int> > array,int target) {
            std::vector<std::vector<int>>::iterator row_num;
            std::vector<int>::iterator col_num;
            for(row_num=array.begin();row_num!=array.end();row_num++){
                for(col_num=(*row_num).begin();col_num!=(*row_num).end();col_num++){
                    if(*col_num==target){
                        return true;
                    } else if(*col_num>target) {
                        continue;
                    }
                }
            }
            return false;
        }
    };
    

    方法二:

     class Solution {
    public:
        bool Find(std::vector<std::vector<int> > array,int target) {
            int row_num = array.size();
            int col_num = (*array.begin()).size();
            for(int i=0;i<row_num;i++){
                for(int j=0;j<col_num;j++){
                    if(array[i][j]==target){
                        return true;
                    } else if(array[i][j]>target){
                        break;
                    }
                }
            }
            return false;
        }
    };
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 一道python难题2
  • ¥15 一道python难题
  • ¥15 用matlab 设计一个不动点迭代法求解非线性方程组的代码
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题
  • ¥15 教务系统账号被盗号如何追溯设备