- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
用C实现链表
用C++实现链表
#include iostream.h#define NULL 0
class Node //节点类{public:?Node(){}?Node(int n){ num=n; next=NULL; }?Node(int n, Node *p){ num=n; next=p;}
?void setNum(int n) {num =n;}?void setNext(Node *p){next =p;}??int getNum(){return num;}?Node *getNext(){ return next;}
private:?int num;?Node *next;};
class Linklist //链表类{public:?Linklist(){head=NULL;}?Linklist(int n){ head = new Node(n); }
?void addAtEnd(int n);?void addAtEnd(Node *p);?void visitAllNode();?void addBeforeNum(Node *p, int num); //在节点值为num之前添加新节点p?void deleteNum(int num);//删除值为num的节点private:?Node *head;};
void Linklist::addAtEnd(int n)??//往链表尾添加节点{?Node *p=head;?if(head==NULL){?head = new Node(n);}?else?{??while(p-getNext()!=NULL)??{ p= p-getNext(); }//用p来指向最后一个节点??p-setNext(new Node(n));//插入节点?}?}void Linklist::addAtEnd(Node *p) //往链表尾添加节点{?Node *pn=head;?if(head==NULL) { head=p; }?else?{??while(pn-getNext()!=NULL)??{ pn=pn-getNext();?}//用pn来指向最后一个节点??pn-setNext(p);//插入节点?}?}
void Linklist::visitAllNode()//遍历链表{?Node *p;?p=head;
?if(p==NULL){cout空链表!endl;}?else?{??cout表头: ;??while(p-getNext()!=NULL)??{???coutp-getNum() -- ;???p=p-getNext();??}??coutp-getNum() 表尾endl;?}}
void Linklist::addBeforeNum(Node *p, int num) //在节点值为num之前添加新节点p{?Node *pn=head,*follow=pn;?if(pn==NULL)?{??cout空链表!插入节点。;??head= p;??return;?}
?while(pn-getNext() != NULL pn-getNum() != num)?// 查找指向节点值为num的节点?{???follow = pn; //follow一直指向pn前的一个节点??pn = pn-getNext();?}?if(pn==head pn-getNum() == num)//找到节点,且为头指针?{??p-setNext(pn);??head=p;?}?else if(pn-getNum() ==??num) //找到此节点,注:follow指向其上一节点?{??p-setNext(pn);??follow-setNext(p);?}?else //没有找到节点,pn指向最后一个节点,将新节点插入链表尾?{??cout没有找到,插入到链表尾。endl;??pn-setNext(p);??}?}
void Linklist::deleteNum(int num) //删除节点{?Node *p=head,*follow=p;?if(p-getNum() == num)//若删除的节点为第1个节点?{??head = p-getNext();??delete p;?}?else?{??while(p-getNext()!=NULL p-getNum() != num)??{????follow = p;//follow一直指向p的前一个节点
您可能关注的文档
- 猪肉炒青菜.doc
- 猎头面试的一点感悟.docx
- 猎狗的故事,值得思考的一个故事.ppt
- 玄天仙侠传2 攻略.doc
- 玉林-国际中小企业交流中心项目规划建议案.doc
- 獐子岛继续扩张海域 支撑未来业绩.pdf
- 玉门市基本情况介绍.doc
- 玉屏县平溪镇紫气山社区简介.doc
- 王府井主业稳健,费用支出高出预期 增持(维持).pdf
- 王志纲名言录-第三种生存经典语录.doc
- 8 黄山奇石(第二课时)课件(共22张PPT).pptx
- 22《纸船和风筝》教学课件(共31张PPT).pptx
- 17 松鼠 课件(共23张PPT).pptx
- 23《海底世界》课件(共28张PPT).pptx
- 21《大自然的声音》课件(共18张PPT).pptx
- 第12课《词四首——江城子 密州出猎》课件 2025—2026学年统编版语文九年级下册.pptx
- 第2课《济南的冬天》课件(共42张PPT) 2024—2025学年统编版语文七年级上册.pptx
- 17 跳水 第二课时 课件(共18张PPT).pptx
- 第六单元课外古诗词诵读《过松源晨炊漆公、约客》课件 统编版语文七年级下册.pptx
- 统编版六年级语文上册 22《文言文二则》课件(共27张PPT).pptx
最近下载
- 住院费用清单模板(可修改).docx VIP
- 新版三年级科学实验报告(上册)(有答案).pdf VIP
- 2025年第三期“1+X”建筑信息模型(BIM)职业技能等级考试——初级——实操试题.pdf VIP
- 2024-2025学年上六年级信息科技《过程与控制》期末检测试卷有答案.docx
- 山西运城市辅警考试真题(含答案).pdf VIP
- 2025北京中考实验压轴题汇编.pdf VIP
- 北京市海淀区七年级(上)期末数学试卷.doc VIP
- 2025-2026学年苏教版(2024)小学科学二年级上册(全册)每课知识点清单 .pdf
- 海洋王销售培训课件.ppt VIP
- 爱心树绘本故事课件.ppt VIP
原创力文档


文档评论(0)