1.使用C++封装一个链表类LinkList
使用C++封装一个链表类LinkList。写出相应一个测试用例
链表需要提供
添加
修改删除
除重
合并 排序创建
销毁等接口。
不能调用库函数或者使用STL等类库
题目延伸***********逆置链表**********
|
LinkNode.h |
|
#ifndef #define #include class { public: int LinkNode* }; #endif |
|
LinkList.h |
#ifndef LINKLIST_H #define LINKLIST_H #include <iostream> #include "LinkNode.h" using namespace std; class LinkList {
public: //作为头节点 LinkNode *m_head; //作为尾节点 LinkNode *m_tail; public: LinkList(); ~LinkList(); void ListInsertIndex(int index,int value); //前插 void ListInsertHead(int value); //尾插 void ListInsertTail(int value); // int ListMerge(LinkList &srclist); //对链表进行排序 void ListSort(bool flag); void ListRemove(int index); //显示所有 void ListShow(); LinkNode * ListFindIndex(int index); //查找第一个出现指定值的节点的地址 LinkNode * ListFindValue(int value); void ListUpdate(int index,int value); //void ListRemoveSame(); }; #endif // LINKLIST_H |
|
LinkList.cpp |
|
#include /** * */ LinkList::LinkList() { //init this->m_head this->m_tail std::cout } /** * */ LinkList::~LinkList() { std::cout } /** * * * */ void { //先查找到第一次出现value的位置 LinkNode LinkNode* pNewNode->m_idata pNewNode->m_pnext if(pNode { this->m_head->m_pnext this->m_tail } else { //新建一个节点 pNewNode->m_pnext pNode->m_pnext } } /** * * */ void { //1.创建一个新的LinkNode节点 LinkNode pNode->m_idata pNode->m_pnext //判断链表是否为空 if(this->m_head { this->m_head this->m_tail } else { pNode->m_pnext this->m_head } } /** * * */ void { //1.创建一个新的LinkNode节点pNode LinkNode pNode->m_idata pNode->m_pnext //2.判断链表是否为空 if(this->m_head { this->m_head //m_tail表示最后一个节点 this->m_tail } else { //尾部节点的下一个节点是新创建的这个节点 this->m_tail->m_pnext this->m_tail } } /** * * * */ void { if(!flag) { //升序 for(LinkNode* { for(LinkNode { if(p1->m_idata { LinkNode pNode.m_idata p1->m_idata //交换数据 p2->m_idata } } } } else { //降序 for(LinkNode { for(LinkNode { if(p1->m_idata { LinkNode pNode.m_idata p1->m_idata p2->m_idata } } } } } /** * * */ void { //找到要删除的节点 LinkNode* //如果没有找到要删除节点,则直接返回 if(pNode { return; } else { if(pNode { this->m_head delete pNode return } //遍历链表 LinkNode* while(pTemp->m_pnext { //如果这个节点的下一个节点恰好是要删除的节点 if(pTemp->m_pnext { pTemp->m_pnext //删除节点 delete pNode break; } //这个临时的节点向下移动 pTemp } //如果是最后一个节点 if(pTemp { pTemp->m_pnext delete pNode return } } } /** * */ void { //判断头节点是否也是空,如果也是空,则返回 if(this->m_head { return; } else { //1.定义一个临时的节点 LinkNode //2.循环,直到最后一个节点 while(pTemp->m_pnext { //输出参数值 std::cout //将临时节点指针向后移 pTemp } std::cout } } /** * * * */ LinkNode { //1.的,如果是则肯定没有,直接返回NULL if(index { std::cout return } else { //判断链表是否是空的,如果是空的,输出结果提示结果然后返回 if(this->m_head { std::cout return } else { LinkNode int while { //当进来了之后先判断,如果查的标记刚好是这个,则直接返回 if(index { return } pTemp // _tempIndex++; } //这里表示恰好这个是最后一个节点 if(index { return } else { std::cout return } } } } /** * * * */ LinkNode* { //判断头节点是否为空,如果为空,则直接返回 if(this->m_head { return } else { //定义一个临时的节点 LinkNode //循环遍历链表,直到最后一个节点 while(pTemp->m_pnext { // if(pTemp->m_idata { return } else { //指针向后移动 pTemp } } //判断最后一个节点的值是否和要查找的值相等 if(pTemp->m_idata { return } } } /** * * * */ void { LinkNode //如果是空,表示没有找到要修改的值 if(pNode { return; } else { pNode->m_idata } } |
#include <iostream> #include "LinkList.h" using namespace std; int main() {
LinkList* linkList = new LinkList(); //向链表的尾部插入值 linkList->ListInsertTail(1); linkList->ListInsertTail(2); linkList->ListInsertTail(3); //向链表的头部插入值 linkList->ListInsertHead(34); linkList->ListInsertHead(105); linkList->ListInsertIndex(5,125); linkList->ListShow(); //显示链表中的值 linkList->ListShow(); std::cout << endl; //的节点的地址 LinkNode* pTargetNode = linkList->ListFindValue(3); //显示出地址 printf("address = %p,data = %d \n",pTargetNode,*pTargetNode);
linkList->ListShow(); LinkNode* pTargetNode2 = linkList->ListFindIndex(4); printf("pTargetNode2 address = %p,data = %d \n",pTargetNode2,*pTargetNode2);
linkList->ListUpdate(1,30); linkList->ListShow(); linkList->ListUpdate(3,30); linkList->ListShow(); linkList->ListRemove(5); linkList->ListShow(); linkList->ListSort(false); linkList->ListShow(); return 0; } |
运行结果: |
1.使用C++封装一个链表类LinkList的更多相关文章
- 使用libzplay库封装一个音频类
装载请说明原地址,谢谢~~ 前两天我已经封装好一个duilib中使用的webkit内核的浏览器控件和一个基于vlc的用于播放视频的视频控件,这两个控件可以分别用在放酷狗播放器的乐库功能和MV ...
- Swift - 简单封装一个工具类模板
创建模板类(封装一个类) 例1:新建一个名字叫做 Product 的类 Product.swift File 的内容 class Product { var name: String var desc ...
- 使用Java封装一个DBUtils类(反射)
刚开始学JavaWeb时,我是调用N个setter方法将从数据库中查询出的数据封装成JavaBean的,极其繁琐. 后来了解SpringJDBC后,发现它提供的接口非常简单,然后就想自己封装一个简单的 ...
- 封装一个帮助类来写文件到android外置存储器上
项目地址:点击打开 项目简介:写文件到android外置存储器的一个帮助类,和它的demo程序 它是如何工作的呢? 1.创建 AppExternalFileWriter 对象并传递context(上下 ...
- 使用AutoFac实现依赖注入(封装一个注册类)
public class AutoFacBootStrapper { public static void CoreAutoFacInit() { var builder = new Containe ...
- 封装一个 员工类 使用preparedStatement 查询数据 (2) 使用 arrayList 集合
创建 员工=类生成 有参构造 get set 方法 toString 方法 package cn.hph; public class emp1 { //创建员工类的属性 private int id; ...
- 封装一个 员工类 使用preparedStatement 查询数据 (1)
创建员工类 自动生成get set 方法 package cn.hph; public class emp { //定义表中的属性 private int id; private String en ...
- 封装一个mysql类(ggshop)
接口 abstract class db{ //连接服务器 public abstract function connect($n,$u,$p); //发送查询 protected abstract ...
- php封装一个接口类
<?phpClass Response{//返回数据 public static function show($code,$message='',$data='',$type = 'json', ...
随机推荐
- POJ 1486二分图的必要边
题意:有n个大小不等透明的幻灯片(只有轮廓和上面的数字可见)A.B.C.D.E…按顺序叠放在一起,现在知道每个幻灯片大小,由于幻灯片是透明的,所以能看到幻灯片上的数字(给出了每个数字的坐标,但不知道这 ...
- [POJ]1279: Art Gallery
题目大意:有一个N边形展馆,问展馆内有多少地方可以看到所有墙壁.(N<=1500) 思路:模板题,半平面交求出多边形的核后计算核的面积. #include<cstdio> #incl ...
- [Helvetic Coding Contest 2017 online mirror]
来自FallDream的博客,未经允许,请勿转载,谢谢, 第一次在cf上打acm...和同校大佬组队打 总共15题,比较鬼畜,最后勉强过了10题. AB一样的题目,不同数据范围,一起讲吧 你有一个背包 ...
- django rest-framework 4.REST的认证和权限
目前,我们的API对谁可以编辑或删除代码段没有任何限制.我们想要一些更先进的行为,以确保:(这段话抄自官网) 代码段始终与创建者相关联. 只有身份验证的用户可以创建片段. 只有片段的创建者可以更新或删 ...
- Python Web学习笔记之多道程序设计技术和操作系统的特性
采用了多道程序设计技术的操作系统具有如下特性 : ① 并发性.它 是指两个或两个以上的事件或活动在同一时间间隔内发生.操作系统是一个并发系统,并发性是它的重要特征,操作系统的并发性指计算机系统中同时存 ...
- Windows下免安装版mysql5.7的初始密码
MySQL5.7之后,初始密码不在默认为空,而是随机生成的密码. 在mysql/data目录下,生成了一个.err文件(等同linux下的log日志文件,此文件会被mysql服务占用). 使用记事本可 ...
- JVM回收方法区内存
很多人认为方法区(或者HotSpot虚拟机中的永久代)是没有垃圾收集的,Java虚拟机规范中确实说过可以不要求虚拟机在方法区实现垃圾收集,而且在方法区进行垃圾收集的“性价比”一般比较低:在堆中,尤其是 ...
- combobox数据绑定
jquery easyui datagrid 可编辑行 combobox数据绑定问题 将带有参数的url地址赋值给变量,然后将变量赋值给url <script type="text/j ...
- Linux下常用设置文件和文件夹读写权限操作
1.查看权限 ls -l xxx.xxx (xxx.xxx是文件名) 2.常见权限 -rw------- (600) 只有所有者才有读和写的权限 -rw-r--r-- (644) 只有所有者才有读 ...
- C stat函数的用法举例(转载)
stat函数讲解表头文件: #include <sys/stat.h> #include <unistd.h>定义函数: int stat( ...