栈应用之数制转换

2018-09-01  本文已影响0人  obidv

头文件:

stackdef.h
#pragma once
//基本定义
#define true 1
#define false 0
#define ok 1
#define error 0
#define infeasible -1
#define overflow -2

typedef int status;

#define init_size 100//预设量
#define increment 10//增量

typedef int selemtype;//设置元素类型

typedef struct {//栈结构
    selemtype *base;
    selemtype *top;
    int stacksize;
}sqstack;

//函数声明
status InitStack(sqstack &s);
status Push(sqstack &s, selemtype e);
status Pop(sqstack &s,selemtype &e);
status StackeEmpty(sqstack s);
status GetTop(sqstack s, selemtype &e);

cpp文件:

StackOperation.cpp
#include <stdio.h>
#include <stdlib.h>
#include "stackdef.h"






//----------函数定义
//-----------初始化栈----------//
status InitStack(sqstack &s) {
    s.base = (selemtype *)malloc(init_size * sizeof(selemtype));
    if (!s.base) exit(overflow);
    s.top = s.base;
    s.stacksize = init_size;
    return ok;
}

//--------栈顶加入元素--------//
status Push(sqstack &s, selemtype e) {
    if (s.top - s.base >= s.stacksize) {
        s.base = (selemtype *)realloc(s.base, (s.stacksize + increment) * sizeof(selemtype));
        s.top = s.base + s.stacksize;
        s.stacksize += increment;
    }
    *s.top++ = e;
    return ok;
}

//-----------栈顶指针下移--------//
status Pop(sqstack &s,selemtype &e) {
    if (s.base == s.top) return error;
    e=*--s.top;

    return ok;
}

//----------判断是否为空栈---------//
status StackeEmpty(sqstack s) {
    if (s.base == s.top) return true;
    else return false;
}

//---------获得栈顶元素-------//
status GetTop(sqstack s, selemtype &e) {
    if (s.top == s.base) return error;
    e = *(s.top - 1);
    return ok;
}
Conversion.cpp
#include <stdio.h>
#include "stackdef.h"
#include <stdlib.h>

//---------函数声明
void Conversion();
//对于输入的任意一个非负十进制整数,打印输出与其等值的二进制数

//----------主函数
int main() {
    Conversion();
    return 0;
}


//----------函数定义
void Conversion() {
    sqstack s;
    int n,e;
    InitStack(s);
    scanf("%d", &n);
    while (n) {
        Push(s, n % 2);
        n = n / 2;
    }
    while (!StackeEmpty(s)) {
        Pop(s,e);
        printf("%d", e);
    }
}
上一篇 下一篇

猜你喜欢

热点阅读