我想打印一個鏈接列表。該程序如下:C++ - 鏈接列表不生成任何輸出
#include<iostream>
#include<vector>
using namespace std;
class Link
{
public:
int iData;
double dData;
Link* pNext;
Link(int id,double dd)
{
iData = id;
dData = dd;
}
void displayLink()
{
cout<<"iData = "<<iData<<"\n";
cout<<"dData = "<<dData<<"\n";
}
};
class OrderedList
{
private:
Link* pRoot;
public:
OrderedList()
{
pRoot = NULL;
}
void insert(int id,double dd)
{
Link* newlink = new Link(id,dd);
Link* pCurrent = pRoot;
Link* pPrev = pRoot;
while(pCurrent!=NULL&&pCurrent->iData<=id)
{
pPrev = pCurrent;
pCurrent = pCurrent->pNext;
}
newlink->pNext = pCurrent;
if(pCurrent==NULL)
{
pCurrent = newlink;
}
else
{
pPrev->pNext = newlink;
}
}
Link* search(int val)
{
Link* pCurrent = pRoot;
while(pCurrent!=NULL&&pCurrent->iData<val)
{
pCurrent = pCurrent->pNext;
}
return pCurrent;
}
bool remove(int val)
{
Link* pCurrent = pRoot;
Link* pPrev = pRoot;
while(pCurrent!=NULL&&pCurrent->iData<val)
{
pPrev = pCurrent;
pCurrent = pCurrent->pNext;
}
if(pCurrent==NULL)
return false;
else
{
Link* temp = pCurrent;
pPrev->pNext = pCurrent->pNext;
delete temp;
return true;
}
}
void displayList()
{
Link* pCurrent = pRoot;
while(pCurrent!=NULL)
{
pCurrent->displayLink();
pCurrent = pCurrent->pNext;
}
}
};
OrderedList ol;
ol.insert(10,10.10);
ol.insert(11,11.11);
ol.insert(12,12.12);
ol.insert(13,13.13);
ol.insert(14,14.14);
ol.insert(15,15.15);
ol.insert(16,16.16);
ol.insert(17,17.17);
ol.insert(18,18.18);
ol.insert(19,19.19);
ol.insert(20,20.20);
ol.insert(21,21.21);
ol.insert(22,22.22);
ol.insert(23,23.23);
ol.insert(24,24.24);
ol.insert(25,25.25);
ol.insert(26,26.26);
ol.insert(27,27.27);
ol.insert(28,28.28);
ol.insert(29,29.29);
ol.displayList();
我面臨的問題是,代碼看起來是正確的,並在紙上運行良好。當我嘗試在計算機上運行它時,它編譯時沒有任何錯誤。但是,執行它時,不顯示輸出。甚至沒有任何錯誤。該程序只是執行而不顯示任何東西。我無法指出問題所在。我認爲代碼很好。請幫我解決這個問題。
看起來很好,你能否也提供調用函數的主體?可能是你的清單是空的... – etzourid
恐怕這看起來好像不太好。 –
pRoot如何變得不是NULL? – Jiminion