继续得到分段错误:11我不确定为什么?

时间:2016-02-19 17:40:57

标签: c++

我需要创建一个程序,它从矩阵中的命令行中找到单词,然后将它们染成红色。这是从左到右读取单词的第一部分。我一直收到一个分段错误:11来自int main中的第二个嵌套for循环。我知道我不打电话给#34;对#34;但那不应该影响分割错误吗?非常感谢任何帮助,非常感谢!

#include "colormod.h"
#include <iostream>
#include <vector>
#include <string>
using namespace std;

int main(int argc, char *argv[]){
  Color::Setting red(Color::FG_RED);
  Color::Setting def(Color::FG_DEFAULT);

  for(int i = 0; i < argc; i++){
    argv[i];
  }

  int x, y;
  cin >> x >> y;
  vector < vector < char > > matrix;
  matrix.resize(x);
  for(int i = 0; i < matrix.size(); i++){
    matrix[i].resize(y);
    for(int k = 0; k < matrix.size(); k++){
      cin >> matrix[i][k];
    }
  }

//THIS IS WHERE THE SEGMENTATION FAULT IS
vector < vector < bool > > empty;
for(int i = 0; i < matrix.size(); i++){
  for(int k = 0; k < matrix.size(); k++){
    if(empty[i][k] == true){
      cout << red << matrix[i][k] << def << " ";
    }
    else{
      cout << matrix[i][k] << " ";
    }
  }
  cout << endl;
 }
}
//THIS IS WHERE THE SEGMENTATION FAULT ENDS

void right(vector < vector < char > > &matrix, vector < vector < bool > > &empty, char *word, int x, int y){
  bool check = false;
  int count = 0;
  int wordLength = strlen(word);
  for(int i = 0; i < wordLength; i++){
    if(y < matrix.size()){
      if(word[i] == matrix[x][y]){
        count++;
      }
    }
    y++;
  }

  if(count == wordLength) check = true;
  if(check){
    y = y - wordLength;
    for(int i = 0; i < wordLength; i++){
      if(y < matrix.size()){
        if(word[i] == matrix[x][y]){
          empty[x][y] = true;
        }
      }
      y++;
    }
  }
}

1 个答案:

答案 0 :(得分:1)

vector < vector < bool > > empty;

创建一个空矢量。然后尝试使用

访问其中的元素
if(empty[i][k] == true)

由于向量中没有任何内容,这将是未定义的行为和分段错误的原因。

你的for循环中的嵌套循环也使用了错误的大小。您正在使用外部矢量大小作为内部矢量的大小,这可能是也可能不正确。你的for循环应该看起来像

for(int i = 0; i < matrix.size(); i++)
    for(int k = 0; k < matrix[i].size(); k++)

或者您可以使用基于范围的for循环,例如

for (auto& row : matrix)
{
    //now row is one row of the outer vector 
    for (auto& col : row)
    {
        // now col is one element in the row
    }
}