Halo_Word 发表于 2019-8-22 09:14:53

二进制转十进制 栈

本帖最后由 Halo_Word 于 2019-11-23 11:27 编辑

#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#define STACK_INIT_SIZE 20
#define STACK_INCREMENT 10

typedef char Elemtype ; // 定义为char类型
typedef struct {
    Elemtype *top ; // 类型为指向char类型的指针
    Elemtype *base ;
    int stacksize ; // 当前的栈的容量
} stack ;

void stack_init (stack *s)
{
    s->base = (Elemtype *)malloc(STACK_INIT_SIZE * sizeof(Elemtype)); // 分配空间
    s->top = s->base ; // 此时栈顶就是栈底
    s->stacksize = STACK_INIT_SIZE ; // 栈的容量
}

void push (stack *s , Elemtype e) // 入栈操作
{
    if (s->top - s->base >= s->stacksize)
    {
      s->base = (Elemtype *)realloc(s->base , (STACK_INIT_SIZE + STACK_INCREMENT)*sizeof(Elemtype)); // 重新分配空间
        s->top = s->base + s->stacksize ; // 此时top指针在栈底,因为被重新分配的缘故,所以得推上去原来的栈顶,以便进行对栈的操作
      s->size += increment ; // 扩容
    }
    *(s->top) = e ; // 进行赋值操作
    s->top++ ; // 升一级指针,指向未被注入数据的栈块
}

void pop (stack *s , Elemtype *e) // 出栈操作,这里需要用到c的指针(即*e)
{
    if (s->top == s->base) // 这是空栈的情况
    {
      return ;
    }
    *e = *(--(s->top)) ; // 这里把top指针指向的栈块数据赋值给e,然后top指针降一级,指向最顶的存有数据的栈块
}

int length (stack *s)
{
    return (s->top - s->base) ; // 返回的是有数据的栈块的数目
}

int main ()
{
    stack *s = NULL ;
    s = (stack *)malloc(sizeof(stack));
    Elemtype c ;
    stack_init(s);
    printf("请输入二进制数,输入#代表结束:\n");
    scanf("%c",&c);
    while (c != '#')
    {
      push(s,c);
      scanf("%c",&c);
    }
    int len = length(s);
    printf("栈的当前容量为:%d\n",len);
    int sum = 0 ;
    for (int i = 0 ; i < len ; i++)
    {
      pop(s,&c);
      sum = sum + (c-48) * pow(2,i);
    }
    printf("将二进制转换成十进制的结果:%d\n",sum);
    return 0 ;
}
页: [1]
查看完整版本: 二进制转十进制 栈