gpt4 book ai didi

我的列表类的 C++ 段错误,但似乎一切都在检查中

转载 作者:行者123 更新时间:2023-11-28 03:28:25 25 4
gpt4 key购买 nike

我正在编写一个有点像 boggle 的程序,但是我在制作 Pairs 并将它们放入列表中然后将它们从列表中取出时遇到了问题。

List.cc
#include <iostream>
#include <cassert>
#include <cstdlib>
#include "list.h"

using namespace std;

List::Node::Node()
{
prev = next = NULL;
}

List:: List()
{
front = new Node()
rear = new Node()
front->next = rear;
rear->prev = front;

currentIndex=0;
current = front->next;
size=0;
}

List::~List()
{
_setCurrentIndex(0);
while(current)
{
Node *temp = current;
current = current -> next;
delete temp;
}
//not showing deep copy function b/c it isn't important for this program
void List::add(const ElementType & item, size_t index)
{
assert(0<=index && index <= size);
_setCurrentIndex(index);
size++;

Node *born = new Node;
born->data = item;
born->prev = current->prev;
born->prev->next = current;
born->prev = born;
current = born;
}

void List::removeAt(size_t index)
{
assert(0<=index<=getSize());
_setCurrentIndex(index);

Node *old = current;
current->prev->next = current->next;
current->next->prev = current->prev;
delete old;
size--;
}

void List::remove(const ElementType & item)
{
for(size_t i=0; i<size; i++)
{
_setCurrentIndex(i);
if(find(item)<getSize())
{
Node *tempOld = current;
current->next->prev = current->prev;
current->prev->next = current->next;
current = current->next;

delete tempOld;
size--;
}
}
}

size_t List::find(const ElementType & item) const
{
for(size_t i=0; i<size; i++)
{
_setCurrentIndex(i)
if(get(i) == item)
return i;
}
return getSize();
}

List::ElementType List::get(size_t index) const
{
assert(0 <= index < size);
_setCurrentIndex(index);
assert(current->next != NULL);
return current->data;
}

size_t List::getSize() const
{
return size;
}

void List::output(std::ostream & ostr) const
{
for(size_t i=0; i<size; i++)
{
_setCurrentIndex(i);
ostr << current->data << " ";
}
ostr << endl;
}

void List:: _setCurrentIndex(size_t index) const
{
int x;
if(currentIndex > index)
x = currentIndex - index;
else
x = index-currentIndex;

if(index < (sizez_t)x)
{
current = front->next;
curentIndex=0;
while(currentIndex != index)
{
current = current->next;
currentIndex++;
}
}
else if((size-index) < (size_t)x)
{
current = rear;
currentIndex = size;
while(currentIndex != index)
{
current = current->prev;
currentIndex--;
}
}
else
{
if(currentIndex > index)
{
while(currentIndex!=index)
{
current = current->prev;
currentIndex--;
}
}
else
{
while(currentIndex!=index)
{
current = current->next;
currentIndex++;
}
}
}
}

似乎当我尝试在我的列表中添加或删除任何内容时,它会导致我的断言出现问题并且它会中止或者它只是出现段错误。

如果我写一个像

这样简单的语句
List history;
Pair p1 = Pair(1,1)
history.add(p1,0)

结果:

scramble: list.cc:154: Pair List::get(size_t) const: assertion 0 <= index <size failed
aborted

最佳答案

断言:

assert(0 <= index < size);

不正确。更改为:

assert(0 <= index && index < size);

关于我的列表类的 C++ 段错误,但似乎一切都在检查中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13307023/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com