鱼C论坛

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

[已解决]C语言数据结构与算法之链表

[复制链接]
发表于 2020-9-21 11:08:27 From FishC Mobile | 显示全部楼层 |阅读模式
50鱼币
小组初学数据结构与算法,希望得到大佬们的优异代码参考。
最佳答案
2020-9-21 11:08:28
本帖最后由 xieglt 于 2020-9-21 13:08 编辑
  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. typedef struct tagLinkList
  4. {
  5.         int data;
  6.         struct tagLinkList * pNext;
  7. }LL,* LPLL;

  8. //增加一个节点
  9. LPLL AddNode(int data)
  10. {
  11.         LPLL p = (LPLL)malloc(sizeof(LL));
  12.         if(p != NULL)
  13.         {
  14.               p->data = data;
  15.             p->pNext = NULL;
  16.         }
  17.         return p;
  18. }

  19. //建立链表
  20. LPLL CreateList(int maxData)
  21. {
  22.         LPLL lpHead = AddNode(0);
  23.         LPLL lpNode = lpHead;
  24.        
  25.         for(int i = 1 ; i <= maxData ; i++)
  26.         {
  27.                 lpNode->pNext = AddNode(i);
  28.                 lpNode = lpNode->pNext;
  29.                 if(lpNode == NULL)
  30.                 {
  31.                         break;
  32.                 }
  33.         }

  34.         return lpHead;
  35. }

  36. //删除链表
  37. void DestoryList(LPLL lpHead)
  38. {
  39.         while(lpHead != NULL)
  40.         {
  41.                 LPLL lpNode = lpHead->pNext;
  42.                 free(lpHead);
  43.                 lpHead =lpNode;
  44.         }
  45. }

  46. //寻找到数第k个元素
  47. long FindLastK(LPLL lpHead,int k)
  48. {

  49.         LPLL fast = lpHead->pNext;
  50.         long nRet = 0;
  51.        
  52.         do
  53.         {       
  54.                 //链表为空,返回
  55.                 if(fast == NULL)
  56.                 {
  57.                         break;
  58.                 }
  59.                
  60.                 //k<=0 退出,倒数计数从1开始,如果想从0开始的话,if(k < 0)
  61.                 if(k <= 0)
  62.                 {
  63.                         break;
  64.                 }
  65.                
  66.                 //倒数计数从1开始,如果想从0开始的话,long i = 0;
  67.                 long i = 1;
  68.                
  69.                 //定义一个快指针,定位到顺数第K个元素,此时fast - head = k
  70.                 while(fast != NULL && i++ < k)
  71.                 {
  72.                         fast = fast->pNext;
  73.                 }
  74.                
  75.                 //如果fast == NULL,说明链表中不足k个元素
  76.                 if(fast == NULL)
  77.                 {
  78.                         break;
  79.                 }
  80.                
  81.                 //定义一个慢指针,slow = head ,所以 fast - slow = K
  82.                 LPLL slow = lpHead->pNext;
  83.                 LPLL lastK = NULL;
  84.                
  85.                 //让fast 指针移动到链表尾部,同时slow指针跟着向后移动
  86.                 //以保证 fast - slow == K
  87.                 //当fast到达链表尾部(NULL)时,slow刚好到达K+1,故而slow之前的节点即为倒数第K个节点
  88.                 while(fast != NULL)
  89.                 {
  90.                         fast = fast->pNext;
  91.                         lastK = slow;
  92.                         slow = slow->pNext;
  93.                 }
  94.                
  95.                 printf("The last %d element is : %d\n",k,lastK->data);
  96.                
  97.                 nRet = 1;
  98.         }while(0);
  99.        
  100.         return nRet;
  101. }

  102. int main()
  103. {
  104.         int test[3] = {6,5,1};

  105.         LPLL lpHead = CreateList(5);
  106.        
  107.         for(int i = 0 ; i < 3 ; i ++)
  108.         {
  109.                 if(FindLastK(lpHead,test[i]) == 0)
  110.                 {
  111.                         printf("can't find the last %d element in list\n",test[i]);
  112.                 }
  113.         }

  114.         DestoryList(lpHead);

  115.         return 0;
  116. }
复制代码
Screenshot_20200920_111556.jpg

最佳答案

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-9-21 11:08:28 | 显示全部楼层    本楼为最佳答案   
本帖最后由 xieglt 于 2020-9-21 13:08 编辑
  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. typedef struct tagLinkList
  4. {
  5.         int data;
  6.         struct tagLinkList * pNext;
  7. }LL,* LPLL;

  8. //增加一个节点
  9. LPLL AddNode(int data)
  10. {
  11.         LPLL p = (LPLL)malloc(sizeof(LL));
  12.         if(p != NULL)
  13.         {
  14.               p->data = data;
  15.             p->pNext = NULL;
  16.         }
  17.         return p;
  18. }

  19. //建立链表
  20. LPLL CreateList(int maxData)
  21. {
  22.         LPLL lpHead = AddNode(0);
  23.         LPLL lpNode = lpHead;
  24.        
  25.         for(int i = 1 ; i <= maxData ; i++)
  26.         {
  27.                 lpNode->pNext = AddNode(i);
  28.                 lpNode = lpNode->pNext;
  29.                 if(lpNode == NULL)
  30.                 {
  31.                         break;
  32.                 }
  33.         }

  34.         return lpHead;
  35. }

  36. //删除链表
  37. void DestoryList(LPLL lpHead)
  38. {
  39.         while(lpHead != NULL)
  40.         {
  41.                 LPLL lpNode = lpHead->pNext;
  42.                 free(lpHead);
  43.                 lpHead =lpNode;
  44.         }
  45. }

  46. //寻找到数第k个元素
  47. long FindLastK(LPLL lpHead,int k)
  48. {

  49.         LPLL fast = lpHead->pNext;
  50.         long nRet = 0;
  51.        
  52.         do
  53.         {       
  54.                 //链表为空,返回
  55.                 if(fast == NULL)
  56.                 {
  57.                         break;
  58.                 }
  59.                
  60.                 //k<=0 退出,倒数计数从1开始,如果想从0开始的话,if(k < 0)
  61.                 if(k <= 0)
  62.                 {
  63.                         break;
  64.                 }
  65.                
  66.                 //倒数计数从1开始,如果想从0开始的话,long i = 0;
  67.                 long i = 1;
  68.                
  69.                 //定义一个快指针,定位到顺数第K个元素,此时fast - head = k
  70.                 while(fast != NULL && i++ < k)
  71.                 {
  72.                         fast = fast->pNext;
  73.                 }
  74.                
  75.                 //如果fast == NULL,说明链表中不足k个元素
  76.                 if(fast == NULL)
  77.                 {
  78.                         break;
  79.                 }
  80.                
  81.                 //定义一个慢指针,slow = head ,所以 fast - slow = K
  82.                 LPLL slow = lpHead->pNext;
  83.                 LPLL lastK = NULL;
  84.                
  85.                 //让fast 指针移动到链表尾部,同时slow指针跟着向后移动
  86.                 //以保证 fast - slow == K
  87.                 //当fast到达链表尾部(NULL)时,slow刚好到达K+1,故而slow之前的节点即为倒数第K个节点
  88.                 while(fast != NULL)
  89.                 {
  90.                         fast = fast->pNext;
  91.                         lastK = slow;
  92.                         slow = slow->pNext;
  93.                 }
  94.                
  95.                 printf("The last %d element is : %d\n",k,lastK->data);
  96.                
  97.                 nRet = 1;
  98.         }while(0);
  99.        
  100.         return nRet;
  101. }

  102. int main()
  103. {
  104.         int test[3] = {6,5,1};

  105.         LPLL lpHead = CreateList(5);
  106.        
  107.         for(int i = 0 ; i < 3 ; i ++)
  108.         {
  109.                 if(FindLastK(lpHead,test[i]) == 0)
  110.                 {
  111.                         printf("can't find the last %d element in list\n",test[i]);
  112.                 }
  113.         }

  114.         DestoryList(lpHead);

  115.         return 0;
  116. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-1 06:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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