数据结构 单一列表

数据结构 单一列表

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。



#ifndef LINKLIST_H

#define LINKLIST_H

#include<iostream>

using namespace std;

template <typename T>

struct Node

{

 T data;

 Node<T> *next;

};

template <typename T>

class LinkList

{

public:

 LinkList();                       //无參构造函数,建立仅仅有头结点的空链表

 LinkList(T a[], int n);           //有參构造函数,建立由n个元素的单链表

 ~LinkList();                      //析构函数

 int Length();                     //求单链表的长度

 T Get(int i);                     //按位查找,查找单链表中的第i个元素的数值

 int Locate(T x);                  //查找该元素在单链表中的位置

 void Insert(int i, T x);          //在第i个位置插入该元素

 T Delete(int i);                  //删除第i个元素

 void PrintList();                 //打印单链表

private:

 Node<T> *first;                  //创建单链表的头指针

};

template <typename T>

LinkList<T>::LinkList()

{

 Node<T> *first;                  //申明头结点

 first = new Node<T>;             //生成头结点

 first->next = NULL;              //初始化头节点

}

template <typename T>

LinkList<T>::LinkList(T a[], int n)

{

 Node<T> *r, *s;                //申明两个暂时结点

 first = new Node<T>;           //生成头结点

 r = first;                     //尾指针初始化

 for (int i = 0; i < n; i++)

 {

  s = new Node<T>;           //生成S结点来存储数组中相应的元素

  s->data = a[i];            //将数组中相应的元素赋值到相应结点的数值部位

  r->next = s;              

  r = s;                     //上两部是将s插入到终端结点之后

 }

 r->next = NULL;

}

template <typename T>

LinkList<T>::~LinkList()

{

 Node<T> *q = NULL;            //建立一个空的结点

 while (first != NULL)         //该循环释放结点的存储空间

 {

  q = first;

  first = first->next;

  delete q;

 }

}

template <typename T>

int LinkList<T>::Length()

{

 Node<T>*p=first->next;

 int count = 0;                   //初始化

 while (p != NULL)

 {

  p = p->next;                //p指针后移

  count++;

 }

 return count;

}

template <typename T>

T LinkList<T>::Get(int i)

{

 Node<T> *p = first->next;

 int count = 1;

 while (p != NULL&&count < i)

 {

  p = p->next;

  count++;

 }

 if (p == NULL)throw”位置”;

 else return p->data;           //单恋表中first是空结点,不算在单链表中的。所以第一个元素是在第一个结点中的。序号是相应的

}

template <typename T>

int LinkList<T>::Locate(T x)

{

 Node<T> *p = first->next;

 int count = 1;               //上述初始化工作量

 while (p != NULL)

 {

  if (p->data == x)

   return count;

  p = p->next;

  count++;

 }

 return 0;                    //推出循环查找,表示查找失败。

}
template <typename T>
void LinkList<T>::Insert(int i, T x)
{
 Node<T> *p = first;
 int count = 0;               //上述初始化工作量
 while (p != NULL&&count < i – 1)
 {
  p = p->next;
  count++;
 }
 if (p == NULL)throw”位置”;
 else
 {
  Node<T> *s;
  s = new Node<T>;
  s->data = x;
  s->next = p->next;
  p->next = s;
 }
}
template <typename T>
T LinkList<T>::Delete(int i)
{
 Node<T> *p = first;
 T x;
 int count = 0;
 while (p != NULL&&count < i – 1)
 {
  p = p->next;
  count++;
 }
 if (p == NULL || p->next == NULL)throw”位置”;
 else
 {
  Node<T> *q;
  q = p->next; x = q->data;
  p->next = q->next;
  delete q; return x;
 }
}
template <typename T>
void LinkList<T>::PrintList()
{
 Node<T> *p;
 p = first->next;
 while (p != NULL)
 {
  cout << p->data<<“->”;
  p = p->next;
 }
}
#endif
*******************************************************************
#include”LinkList.h”
#include<iostream>
#include<iomanip>
using namespace std;
void main()
{
 int a[10] = { 1, 3, 5, 7, 9, 11, 13, 15, 17, 19 };
 int ch;
 LinkList<int> zxh(a,10);
 cout << “生成的单链表为:”;
 zxh.PrintList();
 cout << endl;
 cout << “1-求长度”<<setw(17);
 cout << “2-按位查找” << endl;
 cout << “3-按值查找” << setw(15);
 cout << “4-插入操作” << endl;
 cout << “5-删除操作” << setw(15);
 cout << “6-遍历操作” << endl;
 cout << “请输入您想进行的操作:”;
 cin >> ch;
 switch (ch)
 {
 case 1:zxh.Length(); break;
 case 2:int m1;
  cout << “请输入您想按位查找的位号:”;
  cin >> m1;
  zxh.Get(m1); break;
 case 3:
  int m2;
  cout << “请输入您想查找的值:”;
  cin >> m2;
  zxh.Locate(m2); break;
 case 4:int m3, m4;
  cout << “请输入想插入的位置:”;
  cin >> m3;
  cout << “请输入想插入的元素:”;
  cin >> m4;
  zxh.Insert(m3, m4); break;
 case 5:
  int m5;
  cout << “请输入想删除的位置:”;
  cin >> m5;
  zxh.Delete(m5); break;
 case 6:
  zxh.PrintList();
 }
}
这个单恋表中我自己刚才測试了一下。

基本上没什么大问题。

但似乎球的时间长短是不正确的。我希望我们能提出作证。

版权声明:本文博客原创文章。博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117352.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 单片机声源定位_基于stm32交通灯源代码

    单片机声源定位_基于stm32交通灯源代码stm32声源定位本科毕业设计(论文)基于STM32单片机声源方向识别器设计与实现摘要近年来,基于麦克风阵列的声源定位系统被广泛地应用于电话会议、视频会议、语音增强、助听器等系统中,因此受到了越来越多的关注,已经成为一大研究热点。在各种声源定位方法中,基于到达时延估计的双步定位法原理简单,运算量小,精度相对较高,有利于实时实现,因此它的应用也最为广泛,本文着重研究了该方法。本文首先给出了麦克风阵列…

    2022年9月22日
    6
  • ipv4和ipv6对比(IPV4)

    TCP/IP的心脏是互联网层,这一层主要由IP和ICMP两个协议组成。IP相当于OSI参考模型中的第三层——网络层。而网络层的作用是实现终端节点之间的通信。这种终端节点之间的通信也叫‘点到点’通信。IP地址用于连接在网络中的所有主机中识别出进行通信的目标地址。谷在tcp/ip通信的所有主机中必须设置IP地址。路由控制、多条路由和路由控制表使得数据包可以成功抵达要去的地方。路由控制表记录着此…

    2022年4月15日
    187
  • 新游戏世界合集全文_经典种田文完结推荐

    新游戏世界合集全文_经典种田文完结推荐送给所有爱玩游戏的老鸟们 老游戏中有大量经典作品,其中中文的HGAME更是经典中的经典! ◆告别的年代失色的回忆?——新系统下经典老游戏重玩全攻略◆  “新”与“老”当然是相对的,不过在开篇之前有必要确定我们的讨论范畴,这里的“老”是指为Win98之前的操作系统,包括DOS和Win32/95,而新系统则是指Win98/2000/XP。毫无疑问,有很多老游戏都很值得我们来重温,但重

    2022年9月21日
    2
  • 开启1521端口监听_解决Oracle服务端1521端口无法telnet,服务名未开启监听问题

    开启1521端口监听_解决Oracle服务端1521端口无法telnet,服务名未开启监听问题场景:oracle服务安装在windows本地,oracle客户端在虚拟机中,使用虚拟机连接windows的oracle数据库。问题1:使用虚拟机telnet我本地oracle1521端口,不通解决思路:关闭虚拟机linux防火墙(这个方法有点粗暴,建议在只需要修改防火墙的端口允许通过即可)#1:查看防火状态systemctlstatusfirewalldserviceiptables…

    2022年5月1日
    54
  • DELL服务器数据恢复成功案例

    DELL服务器数据恢复成功案例DELLEqualLogicPS6100采用虚拟ISCSISAN阵列,为远程或分支办公室、部门和中小企业存储部署带来企业级功能、智能化、自动化和可靠性。以简化的管理、快速的部署及合理的价格满足了分支办公室和中小企业的存储需求,同时提供全套企业级数据保护和管理功能、可靠的性能、可扩展性和容错功能,是中型企业级存储的起点产品,但某些物理故障或其他操作都可能会对卷或存储造成破坏,因此对系列存储的数…

    2022年6月30日
    23
  • 实时数据采集传输软件LDM配置

    实时数据采集传输软件LDM配置本环境一共两个机器 cma ldm87 gov cn hostname 机器作为 upstreamLDM cma ldm84 gov cn hostname 机器作为 downstreamLD 下面分享一下这两个 的配置 1upstreamLDM 的配置 nbsp nbsp 1 1ldmd conf 配置重点 nbsp nbsp nbsp nbsp nbsp nbsp ExecEntries 当使用 bin ldmadmin 命令

    2025年10月24日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号