Как исправить подстрочный вектор вне диапазона в C ++ - PullRequest
0 голосов
/ 20 сентября 2019

Я пытаюсь сравнить элементы вектора "координированный список" с элементами вектора "кнопки", и, если четыре различных оператора if подходят для их передачи, увеличьте 1 в векторе "countList".Но проблема в том, что всякий раз, когда я вводю 2 числа для «координаты», которая не может передать оператор if, он получает «векторный индекс вне диапазона» для части;

if ((coordinateList[j][0] >= Buttons[i][0]) 
    && (coordinateList[j][0] <= Buttons[i][1]) 
    && (coordinateList[j][1] >= Buttons[i][2]) 
    && (coordinateList[j][1] <= Buttons[i][3]))

Я нене знаю, как это исправить.

#include <iostream>
#include <vector>

using namespace std;

int main() {

    int numberOfButtons;
    int numberOfClicks;

    cin >> numberOfButtons;

    cin >> numberOfClicks;

    int buttonCoordinate;
    vector <vector<int> > Buttons;

    for (unsigned int i = 0; i < numberOfButtons; i++) {
        vector<int> oneButtonCoordinate;
        for (unsigned int j = 0; j < 4; j++) {
            cin >> buttonCoordinate;
            oneButtonCoordinate.push_back(buttonCoordinate);
        }
        Buttons.push_back(oneButtonCoordinate);
    }



    int XYCoordinate;
    vector <vector<int> > coordinateList;
    vector <int> clickCount;

    for (unsigned int i = 0; i < numberOfClicks; i++) {
        vector<int> oneClickCoordinate;
        for (unsigned int j = 0; j < 2; j++) {
            cin >> XYCoordinate;
            oneClickCoordinate.push_back(XYCoordinate);
        }
        coordinateList.push_back(oneClickCoordinate);
    }


    for (unsigned int i = 0; i < numberOfButtons; i++) {
        clickCount.push_back(0); 
    }

    for (unsigned int j = 0; j < numberOfClicks; j++) {
        for (unsigned int i = Buttons.size() - 1; i >= 0; i--) {
            if ((coordinateList[j][0] >= Buttons[i][0]) && (coordinateList[j][0] <= Buttons[i][1]) && (coordinateList[j][1] >= Buttons[i][2]) && (coordinateList[j][1] <= Buttons[i][3])) {
                clickCount.at(i) += 1;
                break; 
            }
        }
    }


    (skip)


    return 0;
}

Пример правильного ввода и вывода

Вход

2 5

1 5 1 5

3 8 3 8

1 1

3 3

3 5

8 8

3 10

Выход

Button: #1: 1

Button: #2: 3

1 Ответ

1 голос
/ 20 сентября 2019

, поэтому это строка

for (unsigned int i = Buttons.size() - 1; i >= 0; i--)

, которая заканчивается неверным индексом (0xFFFFFFFF по-прежнему> = 0!).

Используйте вместо:

for (int i = (int) Buttons.size() - 1; i >= 0; i--)
...