基于visual Studio2013解决算法导论之020单链表




题目

单链表操作


解决代码及点评

#include <iostream>
using namespace std;

struct LinkNode
{
public:
	LinkNode(int value = 0): nValue(value){ pNext = NULL; }
	~LinkNode() { pNext = NULL; }
private:
	friend class LinkList;
	int nValue;
	LinkNode *pNext;
};

class LinkList
{
public:
	LinkList();
	~LinkList();
	void Insert(int nData);
	void Delete(int nData);
	void Sort();
	bool IsEmpty();
	void Reverse();
	void Destroy();
	int Length();
	LinkNode* Find(int nData);
	bool IsLoop();
	void Print();
private:
	LinkNode *pHead;
};

LinkList::LinkList()
{
	pHead = new LinkNode();
}
LinkList::~LinkList()
{
	Destroy();
}
//从大到小插入
void LinkList::Insert(int nData)
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return;
	}
	LinkNode *pCur = pHead;
	while (pCur->pNext != NULL)
	{
		if (pCur->pNext->nValue < nData)
		{
			break;
		}
		pCur = pCur->pNext;
	}
	LinkNode *pTmp = new LinkNode(nData);
	pTmp->pNext = pCur->pNext;
	pCur->pNext = pTmp;
}

void LinkList::Delete(int nData)
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return;
	}
	if (pHead->pNext == NULL)
	{
		cout<<"链表为空!"<<endl;
		return;
	}

	LinkNode *pCur = pHead;
	while (pCur->pNext)
	{
		if (pCur->pNext->nValue == nData)
		{
			LinkNode *pDel = pCur->pNext;
			pCur->pNext = pCur->pNext->pNext;

			pDel->pNext = NULL;
			delete (pDel);
		}
		else
		{
			pCur = pCur->pNext;
		}
	}
}

void LinkList::Sort()
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return;
	}
	if (pHead->pNext == NULL)
	{
		cout<<"链表为空!"<<endl;
	}

	LinkNode *pCur = pHead->pNext;
	LinkNode *pPre = pHead;

	LinkNode *pNewHead = new LinkNode();
	while (pCur)
	{
		LinkNode *pTmp = pCur;
		pCur = pCur->pNext;

		//将pTmp结点插入到pNewHead指向的新链表中
		LinkNode *p = pNewHead;  
		while (p->pNext)
		{
			if (p->pNext->nValue > pTmp->nValue)
			{
				break;
			}
			p = p->pNext;
		}
		pTmp->pNext = p->pNext;
		p->pNext = pTmp;       
	}
	delete pHead;
	pHead = pNewHead;
}
bool LinkList::IsEmpty()
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return false;
	}

	return pHead->pNext == NULL;
}

int LinkList::Length()
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return 0;
	}
	int nLength = 0;
	LinkNode *pCur = pHead->pNext;
	while (pCur)
	{
		nLength++;
		pCur = pCur->pNext;
	}

	return nLength;
}
void LinkList::Reverse()
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
	}
	if (pHead->pNext == NULL)
	{
		cout<<"链表为空!"<<endl;
	}
	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;
	}
	delete pHead;
	pHead = NULL;
}
LinkNode* LinkList::Find(int nData)
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return NULL;
	}
	if (pHead->pNext == NULL)
	{
		cout<<"链表为空!"<<endl;
		return NULL;
	}

	LinkNode *pCur = pHead->pNext;
	while (pCur != NULL)
	{
		if (pCur->nValue == nData)
		{
			return pCur;
		}
	}

	return NULL;
}
void LinkList::Print()
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return;
	}
	if (pHead->pNext == NULL)
	{
		cout<<"链表为空!"<<endl;
		return;
	}
	else
	{
		LinkNode *pCur = pHead->pNext;
		while (pCur)
		{
			cout<<pCur->nValue<<" ";
			pCur = pCur->pNext;
		}
		cout<<endl;
	}
}
bool LinkList::IsLoop()
{
	if (pHead == NULL)
	{
		cout<<"链表未创建!"<<endl;
		return false;
	}
	if (pHead->pNext == NULL)
	{
		cout<<"链表为空!"<<endl;
		return false;
	}

	LinkNode *pFast = pHead->pNext;
	LinkNode *pLow = pHead->pNext;

	while (pFast != NULL && pLow != NULL  && pFast->pNext != NULL)
	{
		pFast = pFast->pNext->pNext;
		pLow = pLow->pNext;
		if (pFast == pLow)
		{
			return true;
		}
	}
	return false;
}

int main()
{
	LinkList list;
	list.Insert(12);
	list.Insert(14);
	list.Insert(2);
	list.Insert(4);
	list.Insert(5);
	list.Insert(4);
	list.Insert(7);
	list.Print();
	list.Delete(5);
	list.Print();

	list.Sort();
	list.Destroy();
	list.Print();

	system("pause");
	return 0;
}


代码下载及其运行

代码下载地址:http://download.csdn.net/detail/yincheng01/6858815

解压密码:c.itcast.cn


下载代码并解压后,用VC2013打开interview.sln,并设置对应的启动项目后,点击运行即可,具体步骤如下:

1)设置启动项目:右键点击解决方案,在弹出菜单中选择“设置启动项目”


2)在下拉框中选择相应项目,项目名和博客编号一致

3)点击“本地Windows调试器”运行


程序运行结果








  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果你在使用 Visual Studio 2013 时遇到无法联机的问题,可能是由于以下几个原因引起的: 1. 网络连接问题:确保你的计算机已连接到互联网,并且网络连接正常。你可以尝试打开网页或其他联网应用程序来确认网络连接是否正常。 2. 防火墙或代理设置:检查你的防火墙或代理设置,确保它们不会阻止 Visual Studio 2013 的网络连接。你可以暂时禁用防火墙或代理,并尝试重新连接。 3. 特定的网络配置:某些网络环境可能会限制或阻止 Visual Studio 2013 的联机功能。你可以尝试在不同的网络环境中使用 Visual Studio 2013,例如在家中或使用移动数据连接。 4. 更新到最新版本:确保你的 Visual Studio 2013 安装程序是最新版本,以便修复可能存在的网络连接问题。你可以访问 Microsoft 的官方网站,下载并安装最新的 Visual Studio 2013 更新补丁。 如果上述方法仍然无法解决问题,你可以尝试以下操作: 1. 重启计算机:有时候重新启动计算机可以解决临时的网络问题。 2. 重新安装 Visual Studio 2013:如果问题仍然存在,你可以尝试卸载并重新安装 Visual Studio 2013,确保正确安装并配置网络连接。 3. 查看日志文件:Visual Studio 2013 通常会生成日志文件,记录与网络连接相关的错误信息。你可以查找并分析这些日志文件,以获取更多关于问题的线索。 如果问题仍然存在,你可能需要联系 Microsoft 的技术支持团队或查阅相关文档,以获取更详细的帮助和指导。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尹成

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值