我目前遇到的問題與添加對我的列表程序,然後吐出來讓它在我的爭奪程序中工作,這意味着找到單詞sorta像boggle,但沒有設置大小,我必須生成文字/字母。C++未定義的參考錯誤使用List類和Pair類
此代碼位於我的scramble.cc程序中。
List history;
bool placeAlreadyUsed(int x, int y, List history)
{
for(size_t i=0; i < history.getSize(); i++)
{
Pair p1 = history.get(i)
if(p1.r == x && p1.c == y)
return true;
}
return false
}
bool findUsersWord(string findThis, string alreadyFound, List &history, int maxR, int maxC)
{
// need to find the findThis base case
if (findThis == alreadyFound)
cout << "SOLVED" << endl;
return true;
// need to find the first letter within the board and then progress around that.
if (alreadyFound.empty())
{
for (int rows = 0; rows < maxR; rows++)
for (int cols = 0; cols < maxC; cols++)
// find the each character within the
if (theBoard[rows][cols] == findThis[0])
{
alreadyFound = findThis[0];
Pair newR;
newR.r = rows;
newR.c = cols;
history.add(newR);
if (findUsersWord(findThis, alreadyFound, history, maxR, maxC))
return true;
else
{
// clear out the found Board
size_t temp = history.getSize()
for(size_t i=0; i<temp; i++
{
history.removeAt(i);
}
}
}
}
else
{
// try and find the next letters within the area around the base letter
// spin around the letter 3 * 3 grid
for (int x= (p1.r > 0 ? p1.r-1: p1.r); y <=(p1.r == (maxR-1) ? p1.r : p1.r+1);x++)
for (int y= (p1.c> 0 ? p1.c-1: p1.c); x<=(p1.c == (maxC-1) ? p1.c : p1.c+1);y++)
if ((board[x][y] == findThis[alreadyFound.length()]) && (!(x==p1.r && y==p1.c)))
// already used letter
if (!placeAlreadyUsed(y,x,history))
{
alreadyFound += findThis[alreadyFound.length()];
Pair newR;
newR.r = x;
newR.c = y;
history.add(newR, alreadyFound.length());
if (findUsersWord(findThis, alreadyFound, history, maxR, maxC))
return true;
else
{
if (alreadyFound.length() > 1)
alreadyFound = alreadyFound.substr(0, alreadyFound.length()-1);
history.removeAt(history.getSize()-1);
}
}
return false;
}
return false;
}
我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++;
}
}
}
}
我正的錯誤是 scramble.cc(+的.text 0x480):未定義的引用列表::名單(名單常量&)」 collect2:LD返回1退出狀態 化妝:* [爭奪錯誤1
任何想法究竟是什麼爲g在做什麼和如何解決這個問題?
編輯:我不會錯過任何包含語句,只是沒有把它們放在
您是否在scramble.cc中包含了list.h? –
是的,我只是沒有把它放在這個代碼 –
錯誤是告訴你,你沒有寫出構造函數'List :: List(const List&)'。您發佈的代碼中沒有這樣的構造函數。所以我認爲解決方案是編寫該構造函數。'List :: List(const List&)'是一個拷貝構造函數,你可能想在寫它之前先閱讀它。同時您還應該寫作業操作員。閱讀約佔「三法則」,http://stackoverflow.com/questions/4172722/what-is-the-rule-of-three – john