爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      数据结构与算法之五 链接列表

      首页 知识中心 数据库 文章详情页

      数据结构与算法之五 链接列表

      2022-11-22 03:00:53 阅读次数:163

      算法,链表

       
      在本章中,你将学习:
      认识链接列表的特性
      执行单链接列表
       
      假定您已经编写了一个算法来产生并存储1到10,00,000之间的所有质数,然后显示它们。
      您如何解决这个问题?
      考虑以下使用数组来解决此问题的算法:
      1.Set I = 0
      2.Repeat step 3 varying N from 2 to 1000000
      3.If N is a prime number
      a.Set A[I] = N 
      b.I = I + 1
      4.Repeat step 5 varying J from 0 to I-1
      5.Display A[J] 
       
      此算法有什么问题?
      1 到 10,00,000之间的质数个数还不知道。如果使用数组来存储这些质数,您不得不武断地声明一个相当大的数组来存储这些质数。
      此方法的缺点,假定您声明数组大小为N:
      如果1 到 10,00,000之间的质数个数多于N,就不能存储所有的质数。
      如果质数个数比 N小得多,则就浪费了许多空间。
       
      因此,如果您预先不知道元素的总数您就不能使用数组来存储这些数。
      那你该怎么做?
      可以使用动态数据结构,它不需要预先指定大小,当需要内存时可以随时进行分配。
      在你声明一个数组时分配连续的内存块。
      让我们假定声明一个大小为10的数组以存储前10个质数。
      如果您知道数组的第一个元素的地址,就可以容易地计算出其他元素的地址。如下所示:
      第一个元素的地址+ (元素的大小×元素索引)
       
      动态分配内存时,可以从内存的任何位置分配内存块。
      因此,与数组不同,这些块可能会不连续,它们可能会随机分布在内存中。
      要访问任何元素,需要知道其地址。
      现在,如果您知道第一个元素的地址,也无法计算出其他元素的地址。
      这是因为所有的元素都是随机存储在内存中。
      因此,使每个分配的内存块能够按序保持下一个块的地址是十分必要的。
      这样为内存块给定了一个链接结构,每个块都链接到序列中的下一块。
      实现此概念的数据结构的示例就是链接列表。
      你可以声明一个变量START,它存储第一个块的地址。
      你现在可以从START 开始并通过下面的链接穿过列表。
      链接列表:
      是一个动态数据结构。
      在需要时允许你分配内存。
      由元素链组成,在此元素链中每一个元素都被指定为一个节点。
       
      节点是链接列表的基本构建块。
      一个节点由两部分组成:
      数据:指的是节点保存的信息。
      链接:保存列表中下一个节点的地址。
       
      链接列表中的最后一个节点不指向任何其它节点。因此,它指向 NULL。
       
      链接列表中的所有节点是显示在内存空间的任意位置的。
      因此,链接列表中的每一个节点都有存储序列中下一个节点地址的链接字段。
       
      要了解列表的第一个节点,声明一个变量/指示字 START,它总是指向第一个节点。
      当列表为空时,START 包含NULL。
       
      让我们使用链接列表解决给定的存储质数的问题。
      1.重复步骤 2, N 介于2 到1000000。
      2.如果 N是一个质数,将它插入到链接列表中。
      a.为新节点分配内存。
      b.在新节点中存储此质数。
      c.在链接列表中附加新节点。
      3.显示存储在链接列表中的质数。
       
      考虑给出的算法以在链接表中插入节点。
      •
       
      1.为新节点分配内存。
      2.
      2.为新节点的数据字段分配值。
      3.
      3.如果 START是 NULL,则:
      a.使 START指向新的节点。
      b.转至步骤 6。
      4.
      4.找到列表中最后一个节点,将它标记为currentNode。要找到列表中的最后一个节点,请执行以下步骤:
      a.使第一个节点成为 currentNode。
      b.重复步骤 c,直到  currentNode的successor 变成NULL。
      c.使 currentNode指向序列中的下一个节点。
       
      5.使 currentNode的 next 字段指向新节点。
      6.
      6.使新节点的 next字段指向 NULL。
       
      为遍历链接表运用算法。
       
      1.使 currentNode指向列表中的第一个节点。
      2.
      2.重复步骤 3和步骤 4,直到 currentNode成为 NULL 为止。
      3.
      3.显示标记为currentNode的节点中包含的信息。
      4.
      4.使 currentNode指向序列中的下一个节点。
       
      编写一算法以在链接列表中删除第一个节点。
       
      1.使列表中的第一个节点成为当前节点。
      2.
      2.使START指向序列中的下一个节点。
      3.
      3.释放标记为当前节点的内存。
       
      编写一算法以删除链接列表中两个节点之间的节点。
       
      1.找到要删除的节点,将要删除的节点标记为当前节点,将它前一个节点标记为前一个节点。要找到当前节点和前一个节点,请执行以下步骤:
      a.将前一个节点设置为 START。
      b.将当前节点设置为START。
      c.重复步骤d和e,直到找到该节点或当前节点变成NULL为止。
      d.使前一个节点指向当前节点。
      e.使当前节点指向序列中的下一个节点。
      2.
      2.使前一个节点的 next字段指向当前节点的后继者。
      3.
      3.释放标记为当前节点的节点内存。
       
      通过定义两个类,在程序中表示链接列表:
      Node类:节点是链接列表中的基础构建块。Node类代表链接列表中的节点。它包括各种数据类型的数据成员,代表要在链接列表中存储的数据,它还包含对类类型(node)的引用以保持对序列中下一个节点的引用。
      // C# 代码
      class Node
      {
         public int data;
           public Node next;   // 包含序列中下一个
                             // 节点地址的变量
      }
       

      // C++ 代码
      class Node
      {
         public:
          int data;
          Node *next;   // 指向序列中下一个节点
       };
      List类:该类由一组执行链接列表的操作组成。这些操作是插入、删除、搜索和遍历。它还包含变量/指针START的声明,START始终指向列表中的第一个节点。
      // C# 代码
       class Node
      {
         public int data;
           public Node next;   // 包含序列中下一个
                             // 节点地址的变量
        }
       
      // C# 代码
          class List
      {
      private Node START;
      List()
      {
      START = NULL;
      }
      public void addNode(int element){}
        public bool search(int element, ref Node previous, ref Node current) {}
        public bool delNode(int element) {}
        public void traverse() {}
        }
      cing:"100 50 0";mso-margin-left-alt:219;mso-char-wrap:1;mso-kinsoku-overflow:1'>    
       
      // C# 代码
      class List
        {
          Node * START;
          public:
          List()
         {
       START = NULL;
         }
         void addNode(int element);
         bool search(int element, Node *previous, Node  *current);
         bool delNode(int element);
         void traverse();
       };
      6;mso-char-wrap:1;mso-kinsoku-overflow:1'>    
       
      问题描述:
      编写一个程序,对单链接列表执行插入、搜索、删除和遍历操作,该列表存储了班级中的学生记录。每个记录具有以下信息:
      学生的注册号
      学生姓名
       
      小结
       
      在本章中,你已经学到:
      单链接列表中,每个节点包含:
      信息
      列表中下一个节点的地址
      单链接列表只可以按一个方向遍历。
      链接列表中的删除和插入操作比数组快,但是,链接列表中的元素访问速度比数组要慢。
       
      /*
      创建链表,通过使用节点类来创建
      */
      using System;
      class Node
      {
      	public int 	data;		//data用来存放节点的数据
      	public Node 	next;		//next(节点对象)用来存放下一个节点的地址
      }
      
      class CreateList
      {
      	private Node start;		//头指针存放第一个节点的地址.
      	private Node current;	//定义个当前节点对象,用来遍历链表.
      	private Node previous;	//前驱节点.
      	public CreateList()
      	{
      		start=null;					//当初始化类时,设置头指针为空	
      	}		
        /*优化的创建链表的方法*/
        public void create2()
        {
        	previous=current=start=null;		//最开始的时候都为空,就是链表为一个空链表.
        	Console.Write("请输入您要创建链表的个数:");
        	int k=Convert.ToInt32(Console.ReadLine());
        	for(int i=0;i<k;i++)
        	{
        		Console.Write("请输入您要插入的第"+(i+1).ToString()+"节点数据:");	
        		
        		current=new Node();
        		current.data=Convert.ToInt32(Console.ReadLine());	
        		
        			if(start==null)
        				start=current;
        			else
        				previous.next=current;
        			
        			previous=current;  			
        	}
        }
      	public void create()		//创建链表的方法:笨蛋方法(最为朴素的方法)
      	{		Node first=null;
      		if(start==null)
      		{
      			first=new Node();	//1.分配内存	
      			Console.Write("请输入第一个节点值:");	
      			first.data=Convert.ToInt32(Console.ReadLine());				//2.设定数据域里面的数据为2
      			first.next=null;   //3.设定地址域里面的地址为null
      			start=first;			//4.建链接
      			current=first;		//当前节点为第一个节点.
      		}
      		//------------------添加质数为3的节点
      		Node second=new Node();		//1。分配内存
      		Console.Write("请输入第二个节点值");
      		second.data=Convert.ToInt32(Console.ReadLine());						//2.设数据
      		second.next=null;					//3.设地址
      		first.next=second;				//4.将第一个节点指向第二个节点	
      		//---------------------
      		Node third=new Node();		//1。分配内存
      		Console.Write("请输入第3个节点值");
      		third.data=Convert.ToInt32(Console.ReadLine());						//2.设数据
      		third.next=null;					//3.设地址
      		second.next=third;				//4.将第2个节点指向第3个节点	
      		//---------------------------
      		Node fourth=new Node();		//1。分配内存
      		Console.Write("请输入第4个节点值");
      		fourth.data=Convert.ToInt32(Console.ReadLine());						//2.设数据
      		fourth.next=null;					//3.设地址
      		third.next=fourth;				//4.将第3个节点指向第4个节点
      		//-------------------------
      		Node fifth=new Node();		//1。分配内存
      		Console.Write("请输入第5个节点值");
      		fifth.data=Convert.ToInt32(Console.ReadLine());						//2.设数据
      		fifth.next=null;					//3.设地址
      		fourth.next=fifth;				//4.将第4个节点指向第5个节点			
      	}//创建结束
      	public void scan()		//遍历链表的方法
      	{
      		current=start;		//从头指针开始
      		int i=1;
      		while(current!=null)
      		{
      				Console.WriteLine("第"+i+"个节点数据为:"+current.data);
      				current=current.next;		//将当前节点的下一个节点的地址给current,以便current去访问下一个节点.
      				i++;
      		}
      	}
      	//插入新节点
      	public void insert()
      	{
      		Console.WriteLine("请输入您要插入的新节点数据");
      		int i=Convert.ToInt32(Console.ReadLine());
      		Node newnode=new Node();
      		newnode.data=i;
      		
      		/*判断新节点是否为空,并且链表当中没有该节点:在头节点之前插入*/	
      		if((start==null)||(i<=start.data))
      		{
      			if((start!=null)&&(i==start.data))	
      			{
      				Console.WriteLine("\n重复节点不允许");
      				return;	
      			}
      			newnode.next=start;
      			start=newnode;
      			return;
      		}
      		/*在列表中间插入*/
      		previous=current=start;	//设置为开始头节点
      		while((current!=null)&&(i>=current.data))
      		{
      			if(i==current.data)
      			{
      				Console.WriteLine("\n重复数据不允许");
      				return;	
      			}	
      			previous=current;
      			current=current.next;
      		}
      		/*找到前驱节点和后继节点之后*/
      		newnode.next=current;
      		previous.next=newnode;
      	}
      	//搜索链表元素
      	public void search()
      	{
      		Console.WriteLine("请输入您要查找的数据:");
      		int i=Convert.ToInt32(Console.ReadLine());	//1.定义一个要搜索的数字
      		Node current=start;	//2.定义当前节点对象current
      		while((current!=null)&&(current.data!=i))	//3.如果当前节点不为空,并且当前节点数据不等于你输入的数据,则循环.
      		{				
      				current=current.next;
      				
      		}
      		//4。判断是找到了还是没有找到
      		if(current==null)
      			Console.WriteLine("没有找到");
      		else             
      			Console.WriteLine("已经找到了您输入的数据");		
      	}
      	//删除链表元素
      	public void delete()
      	{
      		Console.WriteLine("请输入您要删除的元素");
      		int i=Convert.ToInt32(Console.ReadLine());
      		
      		previous=current=start;		//设定当前节点为头指针指向的节点.
      		
      		if(start==null)
      		{
      			Console.WriteLine("吃饱了撑的,开始乱删了,滚!XXXXXXXX");	
      		}else if(current.data==i)
      		{
      				start=current.next;
      				current.next=null;	//书上忽略了,由系统自动回收不用的内存.
      		}else		//否则,有多个节点,要删除我们指定的节点.
      		{
      				while((current!=null)&&(current.data!=i))
      				{//要找下一个符合条件的节点
      					previous=current;		//在找符合要求的节点之前,将原来节点的地址给previous
      					current=current.next;	//当前节点指向下一个节点.
      				}
      				if(current==null)
      					Console.WriteLine("没有找到!");
      				else
      					previous.next=current.next;		//将要删除的节点的后继节点地址给前驱节点的next.
      		}
      		
      	}
      	/*
      	1.定义要删除节点的前驱节点对象:previous;要删除节点:current
      	2.previous和current都指向start
      	3.遍历链表,以便找到要删除的节点.到底什么时候遍历链表呢?
      	while(current!=null)并且(current.data!=17)
      	{
      			previous=current;
      			current=current.next;	// 要查找下一个节点,同时,前驱节点指向刚才的current节点.
      	}
      	如果current==空:null
      		说明没有找到
      	else	
      		找到了则: previous.next=current.next;
      	
      	*/
      	public static void Main(string[]args)
      	{
      		CreateList list=new CreateList();
      		//list.create2();	//创建链表	
      		list.scan();
      		list.insert();
      		list.delete();
      		list.scan();
      		//list.search();
      	}
      }


       
      /*
      针对链表为空的时候进行插入一个节点的实现;
      链表的实现通过节点类来实现.
      */
      using System;
      class Node	//定义一个节点类
      {
      	public int data;		//数据
      	public Node next;		//next:存放下一个节点的地址.	
      }
      //定义实现对节点操作的类
      class	LinkedListInsert
      {
      	//定义一个头指针的属性
      	private Node Start;
      	private Node current;	//当前节点.
      	//定义构造方法
      	public LinkedListInsert()
      	{
      		Start=null;	
      	}
      		
      	//定义一个静态插入方法
      	public void insert()
      	{ //直接赋值 
      		if(Start==null)
      		{
      				//1.第一步是给新的节点分配内存
      				Node first= new Node();  //分3步画图,记到本上.
      				//2.设置新节点的数据为2
      				first.data=2;
      				//3.将新节点(即质数为2的节点)的地址给头指针,即头指针指向质数为2的节点
      			  Start=first;
      			  //4.设置fist的下一个节点为空(null)
      			  first.next=null;	
      			  //----------------------下面所实现的就应该再插入一个节点的情况;仍然按照插入第一个节点的情况步骤来做,不同点注意将新的点地址给谁了?     
      			  Node second=new Node();
      			  second.data=3;
      			  first.next =second;   //将质数3的节点放到第一个节点地址域
      			  second.next=null;
      			  //-----------------------质数为5的节点
      			  Node third=new Node();
      			  third.data=5;
      			  second.next=third;
      			  third.next=null;
      			  
      		}
      	}
      	//浏览节点方法
      	public void scan()	
      	{
      		//需要判断,如果节点不为空,则输出节点的数据域里的内容
      		current=Start;
      		int i=0;
      		while(current!=null)
      		{
      			Console.WriteLine("第{0}节点的数据为:{1}",i+1,current.data);
      			current=current.next;
      			i++;
      		}
      		
      	}
      	public static void Main(string[]args)
      	{
      			LinkedListInsert list=new LinkedListInsert();
      			list.insert();
      			list.scan();
      	}
      }


      /*问题描述:对单链接列表执行插入、搜索、删除和遍礼操作,该列表存储了班级中的学生记录。每个记录具有如下信息:
      学生的注册号
      学生的姓名
      */
      using System;
      using System.Text;
      
      namespace Sort
      {
      	/*每个节点由信息部分和到下一个节点的地址(链接)组成*/	
      	class Node
      	{
      		public int rollNumber;
      		public string name;
      		//上面的学号和姓名为数据
      		public Node next;	//为地址
      	}
      	class List
      	{
      		Node Start;
      		public List()
      		{
      			Start=null;	
      		}	
      		public void addNode()   /*在列表中添加一个节点*/
      		{
      			int rollNo;
      			string sName;
      			Console.Write("\n请输入学生的学号:");
      			rollNo=Convert.ToInt32(Console.ReadLine());
      			
      			Console.Write("\n请输入学生的姓名:");
      			sName=Console.ReadLine();
      				
      			Node newNode=new Node();	//声明新节点并赋值
      			newNode.rollNumber=rollNo;
      			newNode.name=sName;
      			
      			/*如果要插入的节点是第一个节点*/
      			if((Start==null)||(rollNo<=Start.rollNumber))
      			{
      				if((Start!=null)&&(rollNo==Start.rollNumber))	
      				{
      					Console.WriteLine("\n重复的数据不允许被插入");	
      					return;
      				}//不允许重复的学号.
      				newNode.next=Start;
      				Start=newNode;
      				return;
      			}
      			/*在列表中找到新节点的位置*/
      			Node previous,current;  //定义我们要插入节点的前驱节点和后继节点对象.
      			previous=Start;
      			current=Start;
      			
      			while((current!=null)&&(rollNo>=current.rollNumber))	
      			{
      				if(rollNo==current.rollNumber)
      				{
      					Console.WriteLine("\n重复数据不允许\n");
      					return;	
      				}	
      				previous=current;
      				current=current.next;
      			}
      			/*一旦执行上述循环,新节点的位置就位于前一个和当前节点之间*/
      			newNode.next=current;  //新节点指向后继节点
      			previous.next=newNode;  //将前驱节点指向新节点.
      		}	
      		/*------------------------------------------------------------------*/	
      		public bool delNode(int rollNo)		/*从列表中删除指定的节点*/
      		{
      			Node previous,current;
      			previous=current=null;
      			if(Search(rollNo,ref previous,ref current)==false)	/*检查指定的节点是否在列表中*/
      				return false;
      			previous.next=current.next;
      			if(current==Start)
      				Start=Start.next;
      			return true;
      		}
      		public bool Search(int rollNo,ref Node previous,ref Node current)		/*检查指定的节点是否在列表中*/
      		{
      			previous=Start;
      			current=Start;
      			
      			while((current!=null)&&(rollNo!=current.rollNumber))
      			{
      				previous=current;
      				current=current.next;	
      			}
      			if(current==null)
      				return (false);
      			else
      				return (true);
      		}
      		/*遍历该列表*/
      		public void traverse()
      		{
      			if(listEmpty())
      				Console.WriteLine("\n列表是空的\n");	
      			else
      			{
      				Console.WriteLine("列表的记录是:\n");
      				Node currentNode;
      				for(currentNode=Start;currentNode!=null;currentNode=currentNode.next)
      					Console.Write(currentNode.rollNumber+"   "+currentNode.name+"\n");
      				Console.WriteLine();	
      			}
      		}
      		/*---------------------判断列表是否为空-------------------*/
      		public bool listEmpty()
      		{
      			if(Start==null)
      				return true;
      			else
      				return false;	
      		}
      		/*-----------------------Main()方法--------------------*/
      		public static void Main(string[]args)
      		{
      			List obj=new List();
      			while(true)
      			{
      				try
      				{
      					Console.WriteLine("\n菜单");
      					Console.WriteLine("1.增加列表");
      					Console.WriteLine("2.删除列表");
      					Console.WriteLine("3.遍历列表");
      					Console.WriteLine("4.搜索列表");
      					Console.WriteLine("5.退出");
      					Console.Write("\n请输入您的选择(1-5):");
      					char ch=Convert.ToChar(Console.ReadLine());
      					switch(ch)
      					{
      						case '1':
      							obj.addNode();
      							break;
      						case '2':
      							{
      								if(obj.listEmpty())
      									{
      										Console.WriteLine("\n列表为空");
      										break;	
      								  }
      							Console.Write("\n请输入您要删除学生记录的学号:");
      							int rollNo=Convert.ToInt32(Console.ReadLine());
      							Console.WriteLine();
      							if(obj.delNode(rollNo)==false)
      								Console.WriteLine("\n记录没有发现.");
      							else
      								Console.WriteLine("记录为"+rollNo+"已经删除");
      							}
      							break;
      						case '3':
      							obj.traverse();
      							break;
      						case '4':
      							{
      								if(obj.listEmpty()==true)
      								{
      									Console.WriteLine("\n列表为空");
      									break;	
      								}									
      								Node previous,current;
      								previous=current=null;
      								Console.Write("\n请输入您要搜索学生的学号:");
      								int num=Convert.ToInt32(Console.ReadLine());
      																
      								if(obj.Search(num,ref previous,ref current)==false)
      									Console.WriteLine("\n记录没有发现.");
      								else
      									{
      										Console.WriteLine("\n记录发现");
      										Console.WriteLine("\n学号为:"+current.rollNumber);
      										Console.WriteLine("\n姓名:"+current.name);	
      									}			
      							}
      							break;
      						case '5':
      							return;
      						default:
      							Console.WriteLine("\n无效选项");
      							break;
      					}					
      				}
      				catch(Exception e)
      				{
      					Console.WriteLine("\n请检查输入的值.");
      				}	
      			}	
      		}
      	}
      }


      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.51cto.com/teayear/3187097,作者:跟张哥学编程,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:WEB入门之十五 属性和样式

      下一篇:oracle中decode 结合 sign 使用

      相关文章

      2025-05-19 09:04:14

      《剑指Offer》搜索算法题篇——更易理解的思路~

      《剑指Offer》搜索算法题篇——更易理解的思路~

      2025-05-19 09:04:14
      算法
      2025-05-19 09:04:14

      复杂度的OJ练习

      复杂度的OJ练习

      2025-05-19 09:04:14
      代码 , 复杂度 , 思路 , 数组 , 算法
      2025-05-19 09:04:14

      【牛客网+LeetCode】链表 OJ强训题——高效解法

      【牛客网+LeetCode】链表 OJ强训题——高效解法

      2025-05-19 09:04:14
      数据结构 , 链表
      2025-05-19 09:04:14

      背包问题——“0-1背包”,“完全背包”(这样讲,还能不会?)

      背包问题——“0-1背包”,“完全背包”(这样讲,还能不会?)

      2025-05-19 09:04:14
      动态规划 , 算法
      2025-05-16 09:15:17

      多源BFS问题(4)_地图分析

      多源BFS问题(4)_地图分析

      2025-05-16 09:15:17
      单元格 , 算法 , 网格 , 距离
      2025-05-16 09:15:17

      递归,搜索,回溯算法(3)之穷举,暴搜,深搜,回溯,剪枝

      递归,搜索,回溯算法(3)之穷举,暴搜,深搜,回溯,剪枝

      2025-05-16 09:15:17
      回溯 , 子集 , 数组 , 算法 , 递归
      2025-05-16 09:15:17

      多源BFS问题(2)_飞地的数量

      多源BFS问题(2)_飞地的数量

      2025-05-16 09:15:17
      bfs , grid , 单元格 , 算法
      2025-05-16 09:15:17

      BFS解决最短路问题(4)_为高尔夫比赛砍树

      BFS解决最短路问题(4)_为高尔夫比赛砍树

      2025-05-16 09:15:17
      BFS , lt , 复杂度 , 算法
      2025-05-16 09:15:10

      【C/C++算法】蓝桥杯之递归算法(如何编写想出递归写法)

      【C/C++算法】蓝桥杯之递归算法(如何编写想出递归写法)

      2025-05-16 09:15:10
      结点 , 递归 , 遍历 , 链表 , 题目
      2025-05-16 09:15:10

      BFS解决FloodFill算法(3)_岛屿的最大面积

      BFS解决FloodFill算法(3)_岛屿的最大面积

      2025-05-16 09:15:10
      grid , 复杂度 , 算法
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5233737

      查看更多

      最新文章

      【牛客网+LeetCode】链表 OJ强训题——高效解法

      2025-05-19 09:04:14

      【数据结构】第一章——绪论(2)

      2025-05-14 10:33:31

      java实现3. 无重复字符的最长子串

      2025-05-13 09:50:17

      【数据结构】时间复杂度与空间复杂度

      2025-04-22 09:28:19

      【数据结构】栈和队列

      2025-04-14 08:45:36

      供暖器。 冬季已经来临。 你的任务是设计一个有固定加热半径的供暖器向所有房屋供暖。 在加热器的加热半径范围内的每个房屋都可以获得供暖。

      2025-04-01 10:28:48

      查看更多

      热门文章

      数据结构与算法之四 搜索算法

      2022-11-17 12:37:20

      数据结构算法 简单的面试思考题

      2023-04-25 10:20:57

      【算法】双指针、位运算、离散化、合并区间

      2023-07-26 08:09:55

      【数据结构与算法】带头双向循环链表

      2023-07-26 08:11:49

      LinkedList 基本使用

      2023-07-25 08:20:12

      【数据结构与算法】链表

      2023-07-26 08:09:37

      查看更多

      热门标签

      数据库 mysql 字符串 数据结构 MySQL 算法 redis oracle java sql python 数据 索引 SQL 查询
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      数据结构习题整理(1.0)

      “非递归” 实现二叉树的“前序、中序、后序、层序”遍历

      给定长度为m的字符串aim,以及一个长度为n的字符串str ,问能否在str中找到一个长度为m的连续子串, 使得这个子串刚好由aim的m个字符组成,顺序无所谓,返回任意满足条件的一个子串的起始位置,未找到返回-1。

      无重复字符串的排列组合

      最长回文子串 -- 三种解答

      【算法】模拟算法——外观数组(medium)

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号