c++双向链表

#include<iostream>
using namespace std;
struct Note
{
	Note *Prev;
	Note *Next;
	int m_iData;
};

class MyListNote
{
public:
	Note *m_pHead;
	Note *m_pTail;
	//判断链表是不是空
	bool isEmpty() { return !m_pHead; };	
	int m_iCount;
	//插入数据,包括头插,尾插,及任意位置插入
	void insertDataAtNote(int index, int iData);
	//随机删除一个数	
	void DeleteDataRandomNote(int index);	
	//改变任意链表上的数据
	void ChangeDataAtNote(int index, int iData);
	//寻找某个数出现的位置,及该数出现的次数
	int FindDataAtNote(int iData,int & Num);	
	//从头到尾遍历输出
	void showHeadToTailNote();	
	//从尾到头遍历输出
	void showTailToHeadNote();			
	MyListNote() { m_pHead = m_pTail = nullptr; m_iCount = 0; };
};

void MyListNote::insertDataAtNote(int index, int iData)
{
	if (isEmpty())
	{
		Note *pNote = new Note();
		pNote->m_iData = iData;
		pNote->Next = NULL;

		m_pHead = m_pTail = pNote;
		m_iCount++;
		return;
	}

	 if (index <= 1)
	{
		Note *pNote = new Note();
	
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值