免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1467 | 回复: 1
打印 上一主题 下一主题

[C] 在本论坛找到一个堆栈的源代码,用了两重指针,请问有必要吗 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-01-04 14:22 |只看该作者 |倒序浏览

  1. #include <stdlib.h>
  2. #include <stdio.h>
  3. #include <malloc.h>
  4. #include <string.h>


  5. typedef struct elementT
  6. {
  7.     struct elementT *next;
  8.     void *data;
  9. }element;

  10. int push(element **stack, void *data)
  11. {
  12.     element *elem = NULL;
  13.     elem = (element *)malloc(sizeof(element));
  14.     if(!elem)
  15.     {
  16.         return -1;
  17.     }
  18.     elem->data = data;
  19.     elem->next = *stack;
  20.     *stack = elem;
  21.     return 0;
  22. }

  23. int pop(element **stack, void **data)
  24. {
  25.     element *elem;
  26.     if(!(elem = *stack))
  27.     {
  28.         return -1; /** the stack is null*/
  29.     }
  30.     *data = elem->data;
  31.     *stack = elem->next;
  32.     free(elem->data);
  33.     elem->next = NULL;
  34.     free(elem);
  35.     return 0;
  36. }

  37. int creat_stack(element **stack)
  38. {
  39.     *stack = NULL;
  40.     return 0;
  41. }

  42. int delete_stack(element **stack)
  43. {
  44.     element *elem;
  45.     while(*stack)
  46.     {
  47.         elem = (*stack)->next; /** not elem = *stack->next;*/
  48.         free(*stack);
  49.         *stack = elem;
  50.     }
  51.     return 0;
  52. }

  53. int main(int argc, char *argv[])
  54. {
  55.     char data_c[20] = {'a', 'b', 'c', 'd', 'e', 'f', 'g'};
  56.     int  data_i[20] = {1, 2, 3, 4, 5, 6, 7};
  57.     int i, ret=0;
  58.     element stack_char, stack_int, *stack_c, *stack_i;
  59.     char *p_c;
  60.     int *p_i;
  61.    
  62.     creat_stack(&stack_c);
  63.     creat_stack(&stack_i);
  64.    
  65.     for(i=0; i<7; i++)
  66.     {
  67.         ret = push(&stack_c, (void *)&data_c[i]);
  68.         if(ret)
  69.         {
  70.             printf("push element to stack_c error\n");
  71.             return -1;
  72.         }      

  73.         ret = push(&stack_i, (void *)&data_i[i]);         
  74.         if(ret)        
  75.         {
  76.                 printf("push element to stack_i error\n");
  77.                 return -1;
  78.         }      
  79.     }

  80.     for(i=0; i<7; i++)   
  81.     {
  82.         ret = pop(&stack_c, (void **)&p_c);
  83.         if(ret)        
  84.         {
  85.                 printf("pop element to stack_c error\n");
  86.                 return -1;
  87.         }               
  88.         printf("pop stack_c element [%c]\n", *(char *)p_c);
  89.     }

  90.     for(i=0; i<7; i++)   
  91.     {
  92.         ret = pop(&stack_i, (void **)&p_i);
  93.         if(ret)        
  94.         {
  95.                 printf("pop element to stack_i error\n");
  96.                 return -1;
  97.         }               
  98.         printf("pop stack_i element [%d]\n", *(int *)p_i);      
  99.     }
  100.     delete_stack(&stack_i);
  101.     system("pause");   

  102. }

复制代码

论坛徽章:
0
2 [报告]
发表于 2009-01-04 18:27 |只看该作者

更具有通用性

若将 element 改为 void 类型,则可以将任意类型的数据放入栈中。
代码很好,通用性强。
值得学习。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP