鱼C论坛

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

[已解决]数据结构与算法课程的第18讲(线性表13),课后题

[复制链接]
发表于 2021-7-19 09:31:57 | 显示全部楼层 |阅读模式

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

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

x
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>

  4. typedef struct node {
  5.         int data;
  6.         int password;
  7.         struct node* next;       
  8. } Node;

  9. typedef Node* LinkList;

  10. void InitList(LinkList *L);

  11. void Sort(LinkList L);

  12. int main(void)
  13. {
  14.         LinkList L;
  15.        
  16.         InitList(&L);
  17.        
  18.         Sort(L);
  19.        
  20.         return 0;
  21. }

  22. void InitList(LinkList *L)
  23. {
  24.         int i;
  25.         LinkList temp, r;
  26.         *L = (LinkList)malloc(sizeof(Node));
  27.         (*L)->next = NULL;
  28.         r = *L;
  29.        
  30.         for ( i=1; i<=41; i++)
  31.         {
  32.                 temp = (LinkList)malloc(sizeof(Node));
  33.                 if (!temp)
  34.                 {
  35.                         printf("内存分配失败!\n");
  36.                         exit(0);
  37.                 }
  38.                
  39.                 srand(time(0));
  40.                 temp->password = rand() %100 + 1;
  41.                 temp->data = i;
  42.                 temp->next = *L;
  43.                 r->next = temp;
  44.                 r = temp;
  45.         }       
  46.        
  47.         temp = (*L)->next;
  48.        
  49. }

  50. void Sort(LinkList L)
  51. {
  52.         int n = 41;
  53.         int idx = 1;
  54.         int i;
  55.         int m;        // 存储 password
  56.         LinkList temp, r;
  57.        
  58.         temp = (LinkList)malloc(sizeof(Node));
  59.         if (!temp)
  60.         {
  61.                 printf("内存分配失败!\n");
  62.                 exit(0);
  63.         }
  64.        
  65.         r = (LinkList)malloc(sizeof(Node));
  66.         if (!r)
  67.         {
  68.                 printf("内存分配失败!\n");
  69.                 exit(0);
  70.         }
  71.         r = NULL;
  72.        
  73.         temp = L->next;
  74.         free(L);
  75.        
  76.         while (temp != temp->next)
  77.         {
  78.                 m = temp->password;
  79.        
  80.                 m %= n;
  81.                
  82.                 for ( i=1; i < m-1; i++)
  83.                 {
  84.                         temp = temp->next;               
  85.                 }
  86.                
  87.                 r = temp->next;
  88.                 printf("第 %d 位是:%d\n", idx++, r->data);
  89.                
  90.                 temp = r->next;
  91.                 free(r);
  92.         }
  93.        
  94.        
  95.        
  96. }
复制代码



数据结构与算法课程的第18讲(线性表13),课后题,上边是我写的代码,好像是循环链表的指向出了问题,但是我才疏学浅看不出来,有没有帮忙运行一下看看的。
最佳答案
2021-7-22 15:26:43
  1. void InitList(LinkList *L)
  2. {
  3.         int i;
  4.         LinkList temp, r;
  5.         *L = (LinkList)malloc(sizeof(Node));
  6.         (*L)->next = NULL;
  7.         r = *L;
  8.         
  9.         for ( i=1; i<=41; i++)
  10.         {
  11.                 temp = (LinkList)malloc(sizeof(Node));
  12.                 if (!temp)
  13.                 {
  14.                         printf("内存分配失败!\n");
  15.                         exit(0);
  16.                 }
  17.                
  18.                 srand(time(0));
  19.                 temp->password = rand() %100 + 1;
  20.                 temp->data = i;
  21.                 temp->next = *L;
  22.                 r->next = temp;
  23.                 r = temp;
  24.         }        
  25.         
  26.         temp = (*L)->next;   //此处没有正确把链表环形化  正确操作为  temp->next = (*L)->next;
  27.         
  28. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-7-22 15:26:43 | 显示全部楼层    本楼为最佳答案   
  1. void InitList(LinkList *L)
  2. {
  3.         int i;
  4.         LinkList temp, r;
  5.         *L = (LinkList)malloc(sizeof(Node));
  6.         (*L)->next = NULL;
  7.         r = *L;
  8.         
  9.         for ( i=1; i<=41; i++)
  10.         {
  11.                 temp = (LinkList)malloc(sizeof(Node));
  12.                 if (!temp)
  13.                 {
  14.                         printf("内存分配失败!\n");
  15.                         exit(0);
  16.                 }
  17.                
  18.                 srand(time(0));
  19.                 temp->password = rand() %100 + 1;
  20.                 temp->data = i;
  21.                 temp->next = *L;
  22.                 r->next = temp;
  23.                 r = temp;
  24.         }        
  25.         
  26.         temp = (*L)->next;   //此处没有正确把链表环形化  正确操作为  temp->next = (*L)->next;
  27.         
  28. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-12 20:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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