stack栈

./Makefile:

      1 mytest:main.o stack.o                                                                                      
      2     gcc $^ -o $@
      3 main.o:main.c
      4     gcc -I include -c $^ -o $@
      5 stack.o:stack.c
      6     gcc -I include -c $^ -o $@
      7
      8 clean:
      9     rm main.o stack.o mytest

./include/stack.h:

      1 #ifndef __Jerry_stack__                                                                                    
      2 #define __Jerry_stack__
      3
      4 typedef int stackelem;
      5 typedef stackelem * pstackelem;
      6
      7 typedef struct stack
      8 {
      9     stackelem *base;
     10     stackelem *top;
     11
     12     int stacksize;
     13
     14     void * (*initstack)  (void);
     15     void (*destory)   (struct stack *pstack);
     16     int (*incstack)   (struct stack **ppstack);
     17     int (*pushstack)  (struct stack *pstack, stackelem *elem);
     18     int (*popstack)  (struct stack *pstack, stackelem *elem);
     19     int (*sizestack)  (struct stack *pstack);
     20     int (*fullstack)  (struct stack *pstack);
     21     int (*emptystack)  (struct stack *pstack);
     22 }stack;
     23
     24 typedef stack * pstack;
     25
     26 #define STACKINCRSIZE (sizeof(stackelem) << 4)
     27 #define STACKINTSIZE  (STACKINCRSIZE << 10)
     28
     29
     30 /*now, I would like to use C++, but......*/
     31 extern void * initstack(void);
     32 extern void  destory(stack *pstack);
     33 /*with the help of C++, I will not use extern*/
     34
     35 /*use your own method */
     36 #define PUSH(pposition, pvar) \
     37     do \
     38     { \
     39         *(pposition) = *pvar;     \
     40         ++pposition;                  \
     41                                   \
     42     }while(0)
     43
     44
     45 /*use your own method */
     46 #define POP(pposition, pvar) \
     47     do \
     48     { \
     49         --pposition;         \
     50         *pvar = *pposition;  \
     51                              \
     52     }while(0)
     53
     54 /*use your own method */
     55 #define FREE(ppoistion) \
     56     do \
     57     { \
     58         free(ppoistion); \
     59     }while(0)
     60
     61
     62 #endif    

./main.c:

      1 #include "stack.h"                                                                                         
      2 #include <stdio.h>
      3
      4 int main(void)
      5 {
      6     int teni = 18;
      7     int div,mod;
      8     int eighto;
      9     int err;
     10     stackelem elem;
     11
     12     pstack pnumberstack = initstack();
     13     if(!pnumberstack)
     14     {
     15         printf("init stack error\n");
     16         return -1;
     17     }
     18
     19
     20     mod = teni % 16;
     21     teni = teni /16;
     22     while (teni)
     23     {
     24         pnumberstack->pushstack(pnumberstack, &mod);
     25         mod = teni % 16;
     26         teni = teni / 16;
     27     }
     28
     29     pnumberstack->pushstack(pnumberstack, &mod);
     30     while (pnumberstack->top != pnumberstack->base)
     31     {
     32         pnumberstack->popstack(pnumberstack, &elem);
     33         printf("%d",elem);
     34     }
     35     printf("\n");
     36     destory(pnumberstack);
     37     return 0;
     38 }

./stack.c:

      1 #include "stack.h"                                                                                         
      2 #include <stdio.h>
      3 #include <malloc.h>
      4
      5
      6 static int sizestack(stack *pstack);
      7 static int fullstack(stack *pstack);
      8 static int emptystack(stack *pstack);
      9 static int incstack(stack **ppstack);
     10 static int pushstack(stack *pstack, stackelem *elem);
     11 static int popstack(stack *pstack, stackelem *elem);
     12
     13
     14 void * initstack(void)
     15 {
     16     stack *pstack = malloc(sizeof(stack));
     17
     18     if(!pstack)
     19     {
     20         printf("init stack error\n");
     21         goto err_1;
     22     }
     23
     24     pstack->stacksize = STACKINTSIZE;
     25     pstack->base = (stackelem *)malloc(STACKINTSIZE *sizeof(stackelem));
     26     if (!pstack->base)
     27     {
     28         printf("init stack error\n");
     29         goto err_2;
     30     }
     31
     32
     33     pstack->top = pstack->base;
     34
     35     pstack->initstack = initstack;
     36     pstack->destory = destory;
     37     pstack->sizestack = sizestack;
     38     pstack->fullstack = fullstack;
     39     pstack->emptystack = emptystack;
     40     pstack->incstack = incstack;

     41     pstack->pushstack = pushstack;
     42     pstack->popstack = popstack;
     43     return pstack;
     44
     45 err_2:
     46     free(pstack);
     47 err_1:
     48     return NULL;
     49 }
     50
     51 void destory(stack *pstack)
     52 {
     53     if (pstack->base)
     54         FREE(pstack->base);
     55     free(pstack);
     56 }
     57
     58 int sizestack(stack *pstack)
     59 {
     60     return pstack->top - pstack->base;
     61 }
     62
     63 int fullstack(stack *pstack)
     64 {
     65     if(sizestack(pstack) == pstack->stacksize)
     66         return 1;
     67     return 0;
     68 }
     69
     70 int emptystack(stack *pstack)
     71 {
     72     if(sizestack(pstack) == 0)
     73         return 1;
     74     return 0;
     75 }
     76
     77 int incstack(stack **ppstack)
     78 {
     79         (*ppstack)->base = realloc((*ppstack)->base,
     80                                   ((*ppstack)->stacksize + STACKINCRSIZE) * sizeof(stackelem));    

     81         if(!(*ppstack)->base)
     82         {
     83             printf("incstack error\n");
     84             return -1;
     85         }
     86         return 0;
     87 }
     88         
     89 int pushstack(stack *pstack, stackelem *elem)
     90 {
     91     if (fullstack(pstack))
     92     {
     93         int err;
     94         err = incstack(&pstack);
     95         if(err < 0)
     96         {
     97             printf("pushstack errro\n");
     98             return -1;
     99         }
    100     }
    101     PUSH(pstack->top, elem);
    102     return 0;
    103 }
    104
    105 int popstack(stack *pstack, stackelem *elem)
    106 {
    107     if (emptystack(pstack))
    108     {
    109         printf("popstack error\n");
    110         return -1;
    111     }
    112     POP(pstack->top, elem);
    113     return 0;
    114 }                                                                                                          

 

                                                                                               

posted on 2012-12-01 22:30  阿加  阅读(224)  评论(0编辑  收藏  举报

导航