鱼C论坛

 找回密码
 立即注册
查看: 4305|回复: 1

删除单链表中大于minK且小于maxK的元素

[复制链接]
发表于 2020-9-29 22:35:33 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
已知单链表中各结点的元素值为整型且自增有序,设计算法删除单链表中大于minK且小于maxK的所有元素,并释放被删结点的存储空间。
中间的deleteList函数怎么写?为什么?求大佬指教

  1. #include  <iostream>
  2. using  namespace  std;

  3. typedef  int  DataType;
  4. typedef  struct  node{
  5.         DataType  data;
  6.         node*  next;
  7. }node;
  8. node  *first;

  9. void  init(  )
  10. {
  11.         first  =  new  node;
  12.         first->next  =  NULL;
  13.         node*  rear  =  first;
  14.         int  length;
  15.         cin>>length;
  16.         for(int  i=0;i<length;++i){
  17.                 DataType  elem;
  18.                 cin>>elem;
  19.                 node*  s  =  new  node;
  20.                 s->data  =  elem;
  21.                 s->next  =  NULL;
  22.                 rear->next  =  s;
  23.                 rear  =  s;
  24.         }
  25. }
  26. void  deleteList(DataType  minK,DataType  maxk)
  27. {
  28.       

  29.    
  30. }
  31. void  show(  )
  32. {
  33.         node*  p  =  first->next;
  34.         if(p  ==  NULL)  cout<<"Empty";
  35.         while(p  !=  NULL){
  36.                 cout<<p->data<<"  ";
  37.                 p  =  p->next;
  38.         }
  39.         cout<<endl;
  40. }
  41. int  main()
  42. {
  43.         init();
  44.         DataType  minK,maxK;
  45.         cin>>minK>>maxK;
  46.         deleteList(minK,maxK);
  47.         show();
  48.         return  0;
  49. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-9-29 22:55:56 | 显示全部楼层
  1. node *p = new node();
  2.         node *q = new node();
  3.         p = first;
  4.         q = first->next;
  5.         while(q != NULL)
  6.         {
  7.                 if(q->data>minK&&q->data<maxk)
  8.                 {
  9.                         p->next = q->next;
  10.                         delete q;
  11.                         q = p->next;
  12.                 }
  13.                 else
  14.                 {
  15.                         p = p->next;
  16.                         q = p->next;
  17.                 }
  18.         }
复制代码

已解决
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-13 02:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表