鱼C论坛

 找回密码
 立即注册
查看: 2445|回复: 5

哪里有问题呀?看了好多好多遍。没发现错误

[复制链接]
发表于 2022-12-18 21:32:07 | 显示全部楼层 |阅读模式
20鱼币
PWZCX9QB$MN%T5BJM`K0KM5.png
#include <stdio.h>
#include <stdlib.h>

#define STACK_INIT_SIZE 20
#define STACKINCREMENT 10

typedef char ElemType;
typedef struct{
        ElemType *base;
        ElemType *top;
        int size;
}sqStack;

int wd_pow(int i, int j){
        int a, num = 1;

        for (a = 0; a < j; a++){
                num *= i;
        }

        return num;
}

void InitStack(sqStack *s){//初始化
        s->base = (ElemType *)malloc(STACK_INIT_SIZE * sizeof(ElemType));
        if (!s->base ){
                exit (0);
        }
        s->top = s->base;
        s->size = STACK_INIT_SIZE;
}

void push(sqStack *s, ElemType e){//入栈
        if (s->top - s->base >= s->size){
                s->base = (ElemType *)realloc(s->base, (s->size + STACKINCREMENT) * sizeof(ElemType));
                if (!s->base ){
                        exit (0);
                }
                s->top = s->base + s->size;
                s->size = s->size + STACKINCREMENT;
        }

        *(s->top) = e;
        s->top++;
}

void pop(sqStack *s, ElemType *e){//弹栈
        if (s->top == s->base){
                return;
        }
        *e = *--(s->top);
}

int StackLen(sqStack s){//求栈当前容量
        return (s.top - s.base);
}

int main(){
        ElemType c;
        sqStack s1, s2;
        int len, i, j, sum = 0;

        InitStack (&s1);//初始化栈s1,用来存放二进制输入

        printf("请输入二进制数,输入#表示结束! \n");
        scanf("%c", &c);
        while(c != '#'){
                if (c == '0' || c == '1' )//检查输入是否二进制
                        push(&s1, c);
                scanf("%c", &c);
        }

        getchar ();//把\n从缓冲区去掉
        len = StackLen(s1);

        InitStack(&s2); // 初始化栈s2,用来存放转换的八进制
        printf("栈的当前容量是:%d\n", len);
        for(i = 0; i < len; ){
                for(j = 0; j < 3; j++, i++){
                        pop(&s1, &c);
                        sum = sum + (c-48) * wd_pow(2, j);
                        if (s1.base == s1.top){
                                break;
                        }
                }
                push(&s2, sum+48);
                sum =0;
        }
        
        printf("转换为八进制是:");
        while (s2.base != s2.top){
                pop(&s2, &c);
                putchar(c);
        }
        putchar('\n');

        return 0;
}

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-12-19 14:02:25 | 显示全部楼层
成功了
void push(sqStack *s, ElemTyppe e){//入栈
        if (s->top - s->base >= s->size){
                s->base = (ElemTyppe *)realloc(s->base, (s->size + STACK_INIT_SIZE) * sizeof(ElemTyppe));
                if (!s->base ){
                        exit (0);
                }
                s->top = s->base + s->size;
                s->size = s->size + STACKINCREMENT;
        }

        *(s->top) = e;
        s->top++;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-12-19 11:48:13 | 显示全部楼层
78行for语句里面 i 没有++
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-12-19 12:58:19 | 显示全部楼层
焦糖橙子 发表于 2022-12-19 11:48
78行for语句里面 i 没有++

在79行里呀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-12-21 14:20:14 | 显示全部楼层

你用 VS编译器,我看了一下,好像是编译器问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-12-24 11:28:56 | 显示全部楼层
编程追风梦 发表于 2022-12-21 14:20
你用 VS编译器,我看了一下,好像是编译器问题

已经没问题了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-20 22:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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