输入一个单向链表,输出该链表中倒数第K个结点

http://blog.csdn.net/itcastcpp/article/details/39274891
//尹成 单链表操作
#include <iostream>
using namespace std;
class LinkList;struct LinkNode
{
public:LinkNode(int value =0):m_value(value),pNext(NULL){}~LinkNode(){pNext = NULL;}friend class LinkList;int m_value;LinkNode* pNext;
};//带头结点的链表
class LinkList
{
public:LinkList();~LinkList();void Insert(int data);void Delete(int data);void Sort();bool IsEmpty();void Reverse();void Destroy();int Length();LinkNode* Find(int data);bool IsLoop();void Print();LinkNode* FindIndex(int index);//使用下标LinkNode* FindLastNum(int n);//使用两个指针
private:LinkNode* pHead;
};LinkList::LinkList()
{pHead = new LinkNode();
}LinkList::~LinkList()
{Destroy();
}//从大到小插入
void LinkList::Insert(int data)
{if(NULL == pHead){cout<<"料表未创建"<<endl;return;}LinkNode* pCur = pHead;//移动到待插入节点的前一个节点while(pCur->pNext != NULL){if(pCur->pNext->m_value < data)break;pCur = pCur->pNext;	}LinkNode* pTmp = new LinkNode(data);pTmp->pNext = pCur->pNext;pCur->pNext = pTmp;
}void LinkList::Delete(int data)
{if(NULL == pHead){cout<<"链表未创建"<<endl;return;}if(NULL == pHead->pNext){cout<<"链表为空"<<endl;return;}LinkNode* pCur = pHead;while(pCur->pNext){//指向要删除节点的前一个节点if(pCur->pNext->m_value == data){LinkNode* pDel = pCur->pNext;pCur->pNext = pCur->pNext->pNext;pDel = NULL;delete pDel;}elsepCur = pCur->pNext;}
}//从小到大排序
void LinkList::Sort()
{if(pHead == NULL){cout<<"链表未创建"<<endl;return;}if(pHead->pNext == NULL){cout<<"链表为空"<<endl;return;}LinkNode* pCur = pHead;LinkNode* pNewHead = new LinkNode();while(pCur){LinkNode * pTmp = pCur;pCur = pCur->pNext;LinkNode* p = pNewHead;//将pTmp插入到新的链表中 插入时候按照从小到大顺序while(p->pNext){if(p->pNext->m_value > pTmp->m_value){break;}p = p->pNext;}if(pTmp != pHead){pTmp->pNext = p->pNext;p->pNext = pTmp;}//delete pHead;//释放掉原来的内存  这里不注释掉 导致二次释放指针?pHead = pNewHead;}
}
bool LinkList::IsEmpty()
{if(NULL == pHead){cout<<"链表未创建"<<endl;return false;}return pHead->pNext == NULL;
}int LinkList::Length()
{if(NULL == pHead){cout<<"链表未创建"<<endl;return 0;}int nLength = 0;LinkNode* pCur = pHead->pNext;while(pCur){nLength++;pCur=pCur->pNext;}return nLength;
}void LinkList::Reverse()
{if(NULL == pHead){cout<<"链表未创建"<<endl;return;}if(pHead->pNext == NULL){cout<<"链表为空"<<endl;return;}else{LinkNode* pCur = pHead->pNext->pNext;LinkNode* pPre = pHead->pNext;LinkNode* pnext = NULL;while(pCur){pnext = pCur->pNext;pCur->pNext = pPre;pPre = pCur;pCur = pnext;}pHead->pNext->pNext =NULL;pHead->pNext = pPre;}}void LinkList::Destroy()
{if(pHead == NULL){cout<<"链表未创建"<<endl;return;}while(pHead->pNext){LinkNode* pDel = pHead->pNext;pHead->pNext = pDel->pNext;delete pDel;pDel = NULL;}delete pHead;pHead = NULL;
}LinkNode* LinkList::Find(int data)
{if(NULL == pHead){cout<<"链表未创建"<<endl;return NULL;}if(NULL == pHead->pNext){cout<<"链表为空"<<endl;return NULL;}LinkNode* pCur = pHead->pNext;while(pCur){if(pCur->m_value == data)return pCur;pCur= pCur->pNext;	}return NULL;
}void LinkList::Print()
{if(NULL == pHead){cout<<"链表未创建"<<endl;return;}if(NULL == pHead->pNext){cout<<"链表为空"<<endl;return;}else{LinkNode* pCur = pHead->pNext;while(pCur){cout<<pCur->m_value<<" ";pCur = pCur->pNext;}cout<<endl;}
}bool LinkList::IsLoop()
{if(NULL == pHead){cout<<"链表未创建"<<endl;return false;}if(NULL == pHead->pNext){cout<<"链表为空"<<endl;return false;}LinkNode* pFast = pHead->pNext;LinkNode* pLow = pHead->pNext;//pFast->pNext != NULL 这个条件是很关键的while(pFast != NULL &&pLow != NULL && pFast->pNext !=NULL){pFast = pFast->pNext->pNext;pLow = pLow->pNext;if(pFast == pLow)return true;	}return false;
}//返回倒数第n个节点
LinkNode* LinkList::FindIndex(int n)
{if(n <= 0 || n > Length())return NULL;LinkNode* pCur = pHead->pNext;for(int i = 1;i < n;i++){pCur = pCur->pNext;}return pCur;
}//这一种方法利用了中间间隔
LinkNode* LinkList::FindLastNum(int n)
{if(pHead == NULL || pHead->pNext == NULL||n < 0)return NULL;LinkNode* pCur = pHead->pNext;LinkNode* pFirst = pHead->pNext;while(n > 0){pFirst = pFirst->pNext;if(NULL == pFirst)return NULL;n--;}while(pFirst->pNext){pFirst = pFirst->pNext;pCur = pCur->pNext;}return pCur;
}int main()
{LinkList list;  list.Insert(12);  list.Insert(14);  list.Insert(2);  list.Insert(122);  list.Insert(5);  list.Insert(4);  list.Insert(7);  list.Print();  int k;  cout << "请输入要查询倒数第几个结点(计数从0开始):";  cin >> k;  LinkNode *p = list.FindIndex(list.Length() - k);  if (p)  {  cout << p->m_value << endl;  }  LinkNode *p2 = list.FindLastNum(k);  if (p2)  {  cout << p2->m_value << endl;  }cout<<"链表进行排序之后的结果:"<<endl;list.Sort();list.Print();return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/383971.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络层:构成超网(CIDR)

CIDR构成超网 CIDR消除了原来的传统的 A,B, C, D类地址, 使用了各种网络前缀来代替原来分类地址中的网络号和子网号, IP 地址由原来的三级分类又变成了两级分类. 其中网络号和子网号是一个随机的长度. 其中 CIDR 也可以使用 / 的形式来表示, 其中在 / 前面写上网络前缀的位数.…

UVa12169

我们可以暴力枚举a,然后通过x1和x3确定b的值&#xff0c;然后确定其他的数字&#xff0c;一旦出现错误就放弃这组解。 关键问题就在于如何通过a,x1,x3确定b的值 x2 ( x1 * a b) % M x3 ( x2 * a b ) % M ( ( x1 * a b ) % M * a b ) % M x3 - k * M x1 * a % M * a %…

尹成 双循环链表

今天&#xff0c;我们一起用C写一个双链表&#xff0c;具体代码如下&#xff1a; DoubleList.h具体内容如下&#xff1a; [cpp] view plaincopy #include "NodeList.h" template<typename Type> class DoublyList{ public: DoublyList() :head(ne…

堆的基本操作

堆的数据结构 对于堆, 有最大堆和最小堆, 在定义一个堆的时候用一个数组表示堆, 同时为了方便定义堆的大小, 用一个 size 表示堆的有效元素, 同时为了区别最大堆和最小堆, 我们用一个函数指针表示这个堆是最大堆还是最小堆. typedef int (*Compare)(HeapType parent, HeapTyp…

UVa1605

完完全全的构造题 一种比较好想到&#xff08;虽然我没有想到。。&#xff09;的方法是做成一个两层的表格&#xff0c;第一层每一行相同&#xff0c;第二层每一列相同&#xff0c;这样每个都能和其他的相邻了。 输出格式稍微注意一下 #include<cstdio> #include<c…

Linux下的TCP/IP编程----IO复用及IO复用服务端

http://blog.csdn.net/wqc_csdn/article/details/51583901 在之前我们实现的并发服务端时通过床将多个进程来实现的&#xff0c;这种并实现并发的方式简单方便&#xff0c;但是进程的创建和销毁是很消耗系统资源的&#xff0c;在访问量大时服务器很容易出现资源不够用的情况。除…

UVa120

相当于是一个模拟&#xff0c;为了得到合适的顺序&#xff0c;我们的策略是每次找到当前没有被翻的里面最大的&#xff0c;然后把他翻到最前面&#xff0c;然后再翻到合适的位置。 需要判断一下当前是否已经有序&#xff0c;有序就不用翻了。 如果在最开头找到了合适的当前应…

二叉树的相关操作

二叉树的数据结构 typedef char SearchTreeType; typedef struct SearchTreeNode { SearchTreeType key; // 关键码 struct SearchTreeNode* lchild; struct SearchTreeNode* rchild; } SearchTreeNode; 二叉树的初始化 由于我们是用一个指向根节点的指针表示一个二叉树, …

网络层:网关协议

一. 网关 所谓的网管即就是之前路由器的名字, 即路由器和网关是一个东西 二. 内部网关协议 1. RIP协议 路由信息协议 RIP 是内部网关协议 IGP中最先得到的广泛使用的协议. 同时 RIP 是一种分布式基于距离向量的路由选择协议. RIP 协议要求网络中的每一个路由都必须维护自己…

UVa1152

题意很好理解&#xff0c;就是从四个集合里面取出四个数字的和为0&#xff0c;问有多少种取法。 直接枚举肯定是会超时的&#xff0c;所以得想办法优化一下。我们可以将两个集合的所有的和都放在一个数组里面&#xff0c;这样得到两个数组&#xff0c;然后排序&#xff0c;对第…

Linux函数--inet_pton / inet_ntop

http://blog.csdn.net/lindyl/article/details/10427925 inet_pton 和 inet_ntop Linux下这2个IP地址转换函数&#xff0c;可以在将IP地址在“点分十进制”和“整数”之间转换而且&#xff0c;inet_pton和inet_ntop这2个函数能够处理ipv4和ipv6。算是比较新的函数了。 inet_pto…

网络基础: 浅析应用层一

应用层 1. http协议 在 http 中协议分为了协议方案名, 登录信息名, 服务器地址, 服务器端口号(http协议绑定的端口号), 文件类型, 查询的字符串, 片段标识位 2. http 请求协议格式 httpp 总共分为三大部分, 其中首行即就是第一部分, 分为三个区域, 第一去个区域是请方法, 第…

socket 编程篇六之IPO多路复用-select poll epoll

http://blog.csdn.net/woxiaohahaa/article/details/51498951 文章参考自&#xff1a;http://blog.csdn.net/tennysonsky/article/details/45745887&#xff08;秋叶原 — Mike VS 麦克《Linux系统编程——I/O多路复用select、poll、epoll的区别使用》&#xff09; 此外&#x…

UVa11054

挺简单的小模拟。 还是要注意思维的方向&#xff0c;要有切入点&#xff0c;不能像无头苍蝇一样东想一下西想一下&#xff0c;而应该分析问题的性质&#xff0c;然后尝试思维的方向&#xff0c;从不同的方向思考&#xff08;顺序&#xff0c;逆序&#xff0c;排序后&#xff0…

浅谈传输层

1. 传输层的作用 在传输层中有两个特别重要的协议 TCP/UDP . 以快递员送快递为例说明这个问题吧. 在进行包裹传输的过程中快递员需要根据快递上的目的地址(目的计算机)来投递包裹(IP数据报), 加入在快递单上只写了收件人的所在地, 所在单位, 而只写了收件人的姓没有写收件人的…

UVa10375

题目描述很简单,就是求两个组合数的商.可是数字范围很大,肯定不能直接计算. 因此要用到唯一分解定理,即将结果全部表示为素因子的幂的形式. #include<cstdio> #include<cstring> #include<algorithm> #include<climits> #include<cctype> #inc…

I/O复用的 select poll和epoll的简单实现

http://www.cnblogs.com/wj9012/p/3876734.html 一个tcp的客户端服务器程序 服务器端不变&#xff0c;客户端通过I/O复用轮询键盘输入与socket输入&#xff08;接收客户端的信息&#xff09; 服务器端&#xff1a; 1 /*服务器:2 1.客户端关闭后&#xff0c;服务器再向客户端发送…

netstat 相关命令解析

1.列出所有的端口 netstat -a 列出TCP协议的端口 netstat -at UDP协议的端口 netstat -au 2.列出处于监听状态的socket netstat -l 列出监听的TCP端口 netstat -lt 列出监听的UDP端口 netstat -lu 列出监听的UNIX端口 netstat -lx 3.列出协议的统计信息 nestat …

UVa10791

我们可以先用唯一分解定理将这个数字分解成素因子幂的乘积&#xff0c;为了得到最小的和&#xff0c;我们可以发现&#xff1a;每个 素因子的幂单独分开的和是最小的。 先说明每个素因子都是以出现的最大的次数出现。因为最小公倍数一定&#xff0c;因此至少有一个数字的这个素…

TCP相关代码

TCP 基础代码 //tcp_server.c #include<stdio.h> #include<error.h> #include<sys/types.h> #include<string.h> #include<unistd.h> #include<sys/socket.h> #include<netinet/in.h> #include <arpa/inet.h> #include<st…