鱼C论坛

 找回密码
 立即注册
查看: 2533|回复: 4

C语言的循环链表问题

[复制链接]
发表于 2019-10-20 08:22:15 | 显示全部楼层 |阅读模式

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

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

x
假设以带头点的循环链表表示队列,链表长度为n,只设一个指针指向队尾元素节点,不设头指针,试编写相应的队列初始化、入队和出队的算法;

实现要求:

1、输入循环链表长度n;

2、入队m个元素;

3、打印队列中所有元素;

4、出队k个元素;

5、打印队列中的元素;

6、销毁队列。



输入:

8

6

1 2 3 4 5 6

3

输出:

1 2 3 4 5 6

4 5 6

我查了网上的一些代码,感觉都不合适,不能自由输入元素,我写不出来QAQ
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-10-20 14:34:59 | 显示全部楼层
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define DT char    //可用int、unsigned、char
  4. #define SDT " %c"    //对应 "%d"、"%u"、" %c"

  5. typedef struct _data {
  6.         DT x;
  7.         struct _data *next;
  8. } DATA;

  9. DATA* INPUT(int m);
  10. void TEST(DATA *p);
  11. DATA* DELLEN(DATA *p , int dellen);
  12. int DELVAL(DATA *p , DT delval);

  13. int main(int argc, char **argv){
  14.         DATA *now = NULL;    //记录尾指针
  15.         int n , m , del ;    //n最大长度、m数据长度、del删除的长度、val删除的值
  16.         DT val;
  17.         scanf("%d %d",&n,&m);
  18.        
  19.         /*构建单向循环链表*/
  20.         if(n>=m){
  21.                 now = INPUT(m);
  22.                 TEST(now);
  23.         }
  24.        
  25.         /*实现删除指定数目的数据*/
  26.         scanf("%d",&del);
  27.         now = DELLEN(now,del);
  28.         TEST(now);
  29.        
  30.         /*实现删除指定值的数据*/
  31.         scanf(SDT,&val);
  32.         if(DELVAL(now,val)){
  33.                 printf("del val ok!\n");
  34.                 TEST(now);
  35.         }else{
  36.                 printf("can't find the val!\n");
  37.         }
  38.        
  39.         return 0;
  40. }

  41. DATA* INPUT(int m){
  42.         DATA *p , *head ;
  43.         if(m--){
  44.                 head = (DATA*)malloc(sizeof(DATA));
  45.                 head->next = head;
  46.                 scanf(SDT,&head->x);
  47.                 p = head;
  48.         }
  49.         while(m--){
  50.                 p->next = (DATA*)malloc(sizeof(DATA));
  51.                 p = p->next;
  52.                 p->next = head;
  53.                 scanf(SDT,&p->x);
  54.         }
  55.         return p;
  56. }

  57. DATA* DELLEN(DATA *p , int dellen){
  58.         DATA *q;
  59.         while(dellen--){
  60.                 if(p->next == p){
  61.                         p->next = NULL;
  62.                         free(p);
  63.                         p = NULL;
  64.                         printf("error ! dellen > list \n");
  65.                         break;
  66.                 }
  67.                 q = p->next;
  68.                 p->next = p->next->next;
  69.                 free(q);
  70.         }
  71.         (p != NULL)?(q = p):(q = p->next);
  72.         return q;
  73. }

  74. int DELVAL(DATA *p , DT delval){
  75.         DATA *pt = p;
  76.         int i;
  77.         do{
  78.                 if(pt->next->x == delval){
  79.                         p = pt->next;
  80.                         pt->next = pt->next->next;
  81.                         free(p);
  82.                         p = NULL;
  83.                         break;
  84.                 }
  85.                 pt = pt->next;
  86.         }while(pt != p);
  87.         (p == NULL)?(i=1):(i=0);
  88.         return i;
  89. }

  90. void TEST(DATA *p){
  91.         DATA *pt = p->next;
  92.         printf("head = %p , next = %p\n",p,p->next);
  93.         do{
  94.                 printf("add = %p ",pt);
  95.                 printf(SDT,pt->x);
  96.                 printf(" next add = %p\n",pt->next);
  97.                 pt = pt->next;
  98.         }while(pt != p->next);
  99.         printf("\n");
  100. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-10-20 14:37:58 | 显示全部楼层
按照你说的思路做的,希望能帮你。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-10-21 21:55:55 | 显示全部楼层
kin3z 发表于 2019-10-20 14:37
按照你说的思路做的,希望能帮你。

我拿到vs2019 编译不出来啊 有两个错误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-10-24 07:44:28 | 显示全部楼层
kin3z 发表于 2019-10-20 14:37
按照你说的思路做的,希望能帮你。

您好,您的代码指针似乎没做好,指针未初始化,输出一部分乱码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-4 15:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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