Пожалуйста, объясните ошибку сегментации в этом конкретном коде - PullRequest
0 голосов
/ 06 апреля 2019

Я новичок в кодировании, поэтому, естественно, я часто испытываю ошибки кодирования. Я все время сталкивался с ошибками сегментации, и мне было интересно, кто-нибудь сможет объяснить, что это такое, что не так с приведенным ниже кодом и как избежать ошибок сегментации в будущем. Заранее спасибо.

#include <iostream>
#include <algorithm>
#include <vector>

int main() {
  std::vector<std::vector<int> > pointers;
  std::vector<int> squawkers;
  int n, m, s, t, counter = 0;
  std::cin >> n >> m >> s >> t;
  squawkers[s] = 1;
  for (int i = 0; i < m; i++) {
    int a, b;
    std::cin >> a >> b;
    pointers[a].push_back(b);
    pointers[b].push_back(a);
  }
  while (counter < t) {
    t++;
    std::vector<int> temp (n);
    std::fill(temp.begin(), temp.begin()+n-1, 0);
    for (int i = 0; i < n; i++) {
      if (pointers[i].size() != 0) {
        for (int j = 0; j < pointers.size(); j++)
          temp[j] += squawkers[i];
      }
    }
    squawkers = temp;
  }
  int sum;
  for (int i = 0; i < squawkers.size(); i++)
    sum += squawkers[i];
  std::cout << sum << std::endl;
}

1 Ответ

1 голос
/ 06 апреля 2019

Этот короткий код, извлеченный из кода выше, содержит ошибку.

int main() {
  std::vector<int> squawkers;
  std::cin >> s;
  squawkers[s] = 1;
}

Неважно, какое значение имеет s, squawkers - нулевой размер, поэтому любой использование [] на нем - ошибка.

Для новичка весь ваш код достаточно продвинут.Поэтому мне странно, что эта простая ошибка существует.

...