Я реализую функцию C ++, чтобы найти самую большую площадь прямоугольника в гистограмме, которую я использую как часть максимальной прямоугольной проблемы для бинарной матрицы в LeetCode. Функция использует монотонные стеки, чтобы найти следующие меньшие и предыдущие меньшие элементы.ERROR: AddressSanitizer: heap-buffer-overflow on address ...
SUMMARY: undefined-behavior in Solution::largestRectangle
< /code>
минимальный воспроизводимый пример для запуска выпуска: < /p>
#include
#include
#include
using namespace std;
int largestRectangle(vector& row){
int n = row.size();
vector next(n);
vector prev(n);
stack st;
st.push(-1);
for(int i = n - 1; i >= 0; i--) {
while(st.top() != -1 && row[st.top()] >= row) {
st.pop();
}
next = st.top();
st.push(i);
}
st = stack();
st.push(-1);
for(int i = 0; i < n; i++) {
while(st.top() != -1 && row[st.top()] >= row) {
st.pop();
}
prev = st.top();
st.push(i);
}
int maxArea = 0;
for(int i = 0; i < n; i++) {
int l = row;
if(next == -1) next = n;
int b = next - prev - 1;
int area = l * b;
maxArea = max(area, maxArea);
}
return maxArea;
}
int main() {
vector row; // empty vector triggers error
cout
Назначение n следующим , когда это -1 < /p>
Использование стека и нажимает -1 перед петлями < /p>
my aeptry:
phopfure. Проверяет?>
Подробнее здесь: https://stackoverflow.com/questions/797 ... nic-stacks
C ++ Функция наиболее большего размера приводит к тому, что куча-буфер-переполнение с монотонными стеками-как исправить? ⇐ C++
Программы на C++. Форум разработчиков
1757258653
Anonymous
Я реализую функцию C ++, чтобы найти самую большую площадь прямоугольника в гистограмме, которую я использую как часть максимальной прямоугольной проблемы для бинарной матрицы в LeetCode. Функция использует монотонные стеки, чтобы найти следующие меньшие и предыдущие меньшие элементы.ERROR: AddressSanitizer: heap-buffer-overflow on address ...
SUMMARY: undefined-behavior in Solution::largestRectangle
< /code>
минимальный воспроизводимый пример для запуска выпуска: < /p>
#include
#include
#include
using namespace std;
int largestRectangle(vector& row){
int n = row.size();
vector next(n);
vector prev(n);
stack st;
st.push(-1);
for(int i = n - 1; i >= 0; i--) {
while(st.top() != -1 && row[st.top()] >= row[i]) {
st.pop();
}
next[i] = st.top();
st.push(i);
}
st = stack();
st.push(-1);
for(int i = 0; i < n; i++) {
while(st.top() != -1 && row[st.top()] >= row[i]) {
st.pop();
}
prev[i] = st.top();
st.push(i);
}
int maxArea = 0;
for(int i = 0; i < n; i++) {
int l = row[i];
if(next[i] == -1) next[i] = n;
int b = next[i] - prev[i] - 1;
int area = l * b;
maxArea = max(area, maxArea);
}
return maxArea;
}
int main() {
vector row; // empty vector triggers error
cout
Назначение n следующим [i], когда это -1 < /p>
Использование стека и нажимает -1 перед петлями < /p>
my aeptry:
phopfure. Проверяет?>
Подробнее здесь: [url]https://stackoverflow.com/questions/79758165/c-largestrectangle-function-causes-heap-buffer-overflow-with-monotonic-stacks[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия