鱼C论坛

 找回密码
 立即注册
查看: 4736|回复: 2

[已解决]code:blocks的程序可以编译通过,但是执行老停止

[复制链接]
发表于 2015-7-13 22:24:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 lwp 于 2015-7-14 09:38 编辑

下面是我在code:blocks里编辑的程序,和视频教程里的一样,可以编译通过,就是运行时自动停止,有截图,求大神指导!!!:handshake
程序主函数的功能是输入一个二进制数将其转换为十进制数,其他函数为初始化一个栈,有进栈、出栈、求栈长度的功能,我猜测可能是有栈的操作,涉及到内存,所以会自动退出,因为其他程序(带数组操作)就可以运行;当然也可能是程序有问题,编译时检查不到。

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <math.h>

  4. #define STACK_INIT_SIZE 20
  5. #define STACKINCREMENT 10
  6. typedef char ElemType;

  7. //定义一个栈结构
  8. typedef struct
  9. {
  10.         ElemType *base;
  11.         ElemType *top;
  12.         int stacksize;
  13. }sqStack;

  14. //初始化一个栈
  15.   void InitStack(sqStack *s)
  16. {
  17.         s->base = (ElemType*)malloc(STACK_INIT_SIZE * sizeof(ElemType));
  18.         if(!s->base)
  19.         {
  20.                 exit(0);
  21.         }
  22.         s->top = s->base;
  23.         s->stacksize = STACK_INIT_SIZE;
  24. }

  25. //入栈操作
  26.   void Push(sqStack *s,ElemType e)
  27. {
  28.         if(s->top - s->base >= s->stacksize )
  29.         {
  30.                 s->base = (ElemType*)realloc(s->base,(s->stacksize + STACKINCREMENT) * sizeof(ElemType));
  31.                 if(!s->base)
  32.                 {
  33.                     exit(0);
  34.                 }
  35.         s->top = s->base + s->stacksize;
  36.         s->stacksize = s->stacksize + STACKINCREMENT;
  37.         }
  38.         *s->top = e;
  39.         s->top++;
  40. }

  41. //出栈操作
  42.   void Pop(sqStack *s,ElemType *e)
  43. {
  44.         if(s->top == s->base )
  45.                 return;
  46.         *e = *--(s->top);
  47. }

  48. //求栈的当前长度
  49. int Stacklen(sqStack s)
  50. {
  51.         return (s.top - s.base );
  52. }

  53. int main()
  54. {
  55.         ElemType c;
  56.         sqStack s;
  57.         int len,i,sum = 0;
  58.         printf("请输入二进制数,输入#符号表示结束!\n");
  59.         scanf("%c",&c);
  60.         while(c!='#')
  61.         {
  62.                 Push(&s,c);
  63.                 scanf("%c",&c);
  64.         }
  65.         getchar();
  66.         len=Stacklen(s);
  67.         printf("栈的当前容量是:%d\n",len);
  68.         for(i=0;i<len;i++)
  69.         {
  70.                 Pop(&s,&c);
  71.                 sum = sum + (c-48)*pow(2,i);//将二进制转换为十进制
  72.         }
  73.         printf("转化为十进制数是:%d\n",sum);
  74.         return 0;
  75. }
复制代码

U%ELZMJ8$TN$C}_GL%0YWDD.png
最佳答案
2015-7-13 23:22:25
2. 代码大于20行以上时,最好写清自己的思路和注释,这样回答的人才能尽快给大家答案!(避免扔上一大堆代码,说是有错误,请人指点!)
3. 发代码请务必使用编辑器的“添加代码文字”(这个符号:<>)代码不会发请点击我
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-7-13 23:22:25 | 显示全部楼层    本楼为最佳答案   
2. 代码大于20行以上时,最好写清自己的思路和注释,这样回答的人才能尽快给大家答案!(避免扔上一大堆代码,说是有错误,请人指点!)
3. 发代码请务必使用编辑器的“添加代码文字”(这个符号:<>)代码不会发请点击我
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2015-7-14 09:41:51 | 显示全部楼层
牡丹花下死做鬼 发表于 2015-7-13 23:22
2. 代码大于20行以上时,最好写清自己的思路和注释,这样回答的人才能尽快给大家答案!(避免扔上一大堆代 ...

谢谢提醒,新手第一次发帖不太懂,已经按照您的要求重新发了一遍。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-18 21:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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