資源描述:
《靜態(tài)成員和友元實(shí)驗(yàn)報(bào)告.doc》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在應(yīng)用文檔-天天文庫(kù)。
1、[標(biāo)準(zhǔn)實(shí)驗(yàn)報(bào)告]南昌航空大學(xué)實(shí)驗(yàn)報(bào)告2011年11月11日課程名稱(chēng):面向?qū)ο蟪绦蛟O(shè)計(jì)B實(shí)驗(yàn)名稱(chēng):靜態(tài)成員和友元班級(jí):10202327姓名:呂瀟同組人:指導(dǎo)教師評(píng)定:簽名:一、實(shí)驗(yàn)?zāi)康模?)學(xué)習(xí)靜態(tài)成員的使用,理解靜態(tài)成員的特殊用途。(2)學(xué)習(xí)友元函數(shù)及友元類(lèi),領(lǐng)會(huì)友元類(lèi)的作用。二、實(shí)驗(yàn)內(nèi)容(本次實(shí)驗(yàn)要完成的內(nèi)容)應(yīng)用VC++6.0的編輯環(huán)境構(gòu)造一個(gè)類(lèi)Stack,設(shè)計(jì)一個(gè)整數(shù)鏈表類(lèi),實(shí)現(xiàn)棧操作。類(lèi)中需有記錄結(jié)點(diǎn)個(gè)數(shù)的數(shù)據(jù)成員(靜態(tài)成員),要有判空操作。編制應(yīng)用程序,取100次隨機(jī)數(shù)(<1000),如果取到的隨機(jī)數(shù)比前一個(gè)隨
2、機(jī)數(shù)大的話,入棧,然后逐個(gè)取出(即出棧過(guò)程)求其和。用堆分配方法逐個(gè)產(chǎn)生滿(mǎn)足條件(遞增有序)的結(jié)點(diǎn),插入棧中,每當(dāng)出棧時(shí),要及時(shí)將結(jié)點(diǎn)刪除,求和工作放在類(lèi)定義外(友元)。注意:棧中最多會(huì)有100個(gè)元素,最少會(huì)有一個(gè)元素,這是由條件(遞增有序)決定的。具體說(shuō)明如下:structSNode{intdata;SNode*next;};classStack{public:Stack();~Stack();voidPush(inte);//insertadataintostackintPop();//deleteadatafrom
3、stackfriendintGetSum(Stack&);//getsumofstack,friendfunction//friendclassgetsum;//getsumofstack,friendclass,youcantryitusingfriendclassstaticintnum;//staticnumberprivate:SNode*head;};對(duì)棧的入棧過(guò)程與出棧過(guò)程說(shuō)明如下:(1)入棧,即向棧中添加一個(gè)元素,且該元素只能添加到當(dāng)前鏈表最后一個(gè)數(shù)據(jù)元素之后,此時(shí)記錄數(shù)組元素?cái)?shù)據(jù)個(gè)數(shù)的變量應(yīng)該進(jìn)行++操作
4、;(2)出棧,即從鏈表中刪除一個(gè)數(shù)據(jù)元素,且該元素只能是當(dāng)前棧中最后的一個(gè)元素,此時(shí)記錄數(shù)據(jù)元素個(gè)數(shù)的變量應(yīng)該進(jìn)行--操作,也就是說(shuō),入棧及出棧的操作標(biāo)識(shí)實(shí)際上是由記錄數(shù)組中數(shù)據(jù)元素個(gè)數(shù)的變量實(shí)現(xiàn)的。(3)判空,即判斷當(dāng)前棧(即鏈表)是否為空,也就是判斷記錄數(shù)組中數(shù)據(jù)元素個(gè)數(shù)的變量是否為0。三、概要設(shè)計(jì)(實(shí)現(xiàn)的功能,函數(shù)原型及說(shuō)明等)應(yīng)用VC++6.0的編輯環(huán)境構(gòu)造一個(gè)類(lèi)Stack,設(shè)計(jì)一個(gè)整數(shù)鏈表類(lèi),實(shí)現(xiàn)棧操作。類(lèi)中需有記錄結(jié)點(diǎn)個(gè)數(shù)的數(shù)據(jù)成員(靜態(tài)成員),要有判空操作。編制應(yīng)用程序,取100次隨機(jī)數(shù)(<1000),如果
5、取到的隨機(jī)數(shù)比前一個(gè)隨機(jī)數(shù)大的話,入棧,然后逐個(gè)取出(即出棧過(guò)程)求其和。用堆分配方法逐個(gè)產(chǎn)生滿(mǎn)足條件(遞增有序)的結(jié)點(diǎn),插入棧中,每當(dāng)出棧時(shí),要及時(shí)將結(jié)點(diǎn)刪除,求和工作放在類(lèi)定義外(友元)。structSNode{intdata;SNode*next;};鏈表結(jié)構(gòu)體classStack{public:Stack();構(gòu)造函數(shù)~Stack();析構(gòu)函數(shù)voidPush(inte);入棧intPop();出棧friendintGetSum(Stack&);友元函數(shù)intGetSum(Stack&)函數(shù)原型staticint
6、num;靜態(tài)變量用來(lái)計(jì)數(shù)private:SNode*head;四、詳細(xì)設(shè)計(jì)(程序中核心代碼,并要有相應(yīng)注釋——函數(shù)功能、參數(shù)說(shuō)明、重要語(yǔ)句的注解)intStack::num=0;//靜態(tài)成員初始化Stack::Stack()構(gòu)造函數(shù)初始化{head=NULL;}Stack::~Stack()析構(gòu)函數(shù){}boolStack::Push(inte)入棧{SNode*p=newSNode;if(!p)returnfalse;p->data=e;p->next=head;head=p;num++;returntrue;}intS
7、tack::Pop()//出棧函數(shù){SNode*p=newSNode;inte;staticintcount=1;p=head;e=p->data;head=p->next;free(p);count++;returne;}intGetSum(Stack&A)求和函數(shù)定義{intSum=0;for(inti=0;i8、實(shí)驗(yàn)四.cpp(38):errorC2143:syntaxerror:missing';'before'}'C:WindowsSystem32實(shí)驗(yàn)四.cpp(38):fatalerrorC1003:errorcountexceeds100;stoppingcompilation執(zhí)行cl.exe時(shí)出錯(cuò).實(shí)驗(yàn)四.