新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论高级C/C++编程、代码重构(Refactoring)、极限编程(XP)、泛型编程等话题
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 C/C++编程思想 』 → [原创]关于编译器的问题 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 3468 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: [原创]关于编译器的问题 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     hinder 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:14
      积分:118
      门派:IEEE.ORG.CN
      注册:2007/9/24

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hinder发送一个短消息 把hinder加入好友 查看hinder的个人资料 搜索hinder在『 C/C++编程思想 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hinder的博客楼主
    发贴心情 [原创]关于编译器的问题

    #include "stdio.h"
    #define   TRUE  1
    #define   MAXSIZE 50
    typedef       int    datatype;  
    typedef       struct    
    { datatype   stack[MAXSIZE]; 
       int top;    
    } seqstack;          /* 顺序栈的类型定义 */
    seqstack   *a;          /* a为顺序栈 */
    void INITSTACK(seqstack *S)   
    {     S->top=0;      /* 将顺序栈设置为空栈 */
    }/* SEQSTACK_INITSTACK */
     /* 检查顺序栈是否为空栈运算 */
    int  EMPTY(seqstack *S)  
    { if(S->top==0)      return (TRUE);    
      else                   return (NULL); 
    }/* SEQSTACK_EMPTY */
    seqstack *PUSH(seqstack *S, datatype x)
    { if(S->top>=MAXSIZE-1)    /* 检查顺序栈是否满 */
      { printf("栈满溢出错误!\n");
        return(NULL);    /* 若插入元素失败,则返回0 */
      }
      else
      {     /* 将栈顶指针加1使之指向空单元 */
        S->stack[S->top]=x;    /* 将新结点插入栈顶 */
     S->top++;}
      return(S);  /* 插入成功则函数返回新栈顶指针 */
    }/* SEQSTACK_PUSH */
    datatype POP(seqstack *S)    
    { datatype x;       /* 保存栈顶元素数据值 */
      if  (EMPTY(S))                /* 检查顺序栈是否为空 */
      { printf("下溢错误! ");
         return(NULL);       /* 若删除失败返回0 */
       }
      else                          /* 若顺序栈非空删除之*/
       { S->top--;
         x=S->stack[S->top];    /* 暂存栈顶元素 */
         return (x);     
        }
        }/* SEQSTACK_POP */
    datatype    gettop_seqstack(seqstack *S)
    {  if  (EMPTY(S))
       {  printf("栈是空栈! ");
           return(NULL);    
        }
       else  return(S->stack[S->top]); 
    }/* SEQSTACK_GETTOP */

    main()       /* 从键盘输入一批正整数,然后按相反次序输出程序 */
    { int x, n=0;  /* x保留栈顶元素的数据值,n统计输入数据的个数 */
      INITSTACK(a);   /* 将顺序栈初始化置空 */
      printf("\nPlease input data with 0 as a end:\n\n");
      scanf("%d", &x);  /* 输入第一个正整数 */
      while(x!=0)  /* 输入正整数,以-1作为结束标志 */
      { a=PUSH(a, x);  /* 将输入正整数顺序进栈 */
        n++;    scanf("%d", &x); } /* 继续输入下一个正整数 */
        printf("n=%d\n", n); /* 统计输入正整数的个数 */
        while(EMPTY(a)!=1) /* 若栈非空,则依次退栈输出整数 */
        { x=POP(a);  /* 将栈顶元素顺序出栈保存到x中 */
          printf("%d  ", x); /* 打印输出栈顶元素的数据值 */
          n--;  }
       printf("n=%d\n", n);       getchar();
    }/* MAIN */
    这段代码可以在tc2.0上调试通过,但不能在vc6.0上调试通过是为什么。请各位高手指点,小弟不胜感激。


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/4 11:49:00
     
     一分之千 帅哥哟,离线,有人找我吗?射手座1984-11-30
      
      
      威望:1
      等级:研一(随老板参加了WWW大会还和Tim Berners-Lee合了影^_^)
      文章:632
      积分:4379
      门派:XML.ORG.CN
      注册:2006/12/31

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给一分之千发送一个短消息 把一分之千加入好友 查看一分之千的个人资料 搜索一分之千在『 C/C++编程思想 』的所有贴子 引用回复这个贴子 回复这个贴子 查看一分之千的博客2
    发贴心情 
    #include "stdio.h"
    #define   TRUE  1
    #define   MAXSIZE 50
    typedef       int    datatype;  
    typedef       struct     
    { datatype   stack[MAXSIZE];
    int top;    
    } seqstack;          /* 顺序栈的类型定义 */
    seqstack   *a;          /* a为顺序栈 */
    void INITSTACK(seqstack *S)   
    {     S->top=0;      /* 将顺序栈设置为空栈 */
    }/* SEQSTACK_INITSTACK */
    /* 检查顺序栈是否为空栈运算 */
    int  EMPTY(seqstack *S)  
    { if(S->top==0)      return (TRUE);    
    else                   return (NULL);
    }/* SEQSTACK_EMPTY */
    seqstack *PUSH(seqstack *S, datatype x)
    { if(S->top>=MAXSIZE-1)    /* 检查顺序栈是否满 */
    { printf("栈满溢出错误!\n");
    return(NULL);    /* 若插入元素失败,则返回0 */
    }
    else
    {     /* 将栈顶指针加1使之指向空单元 */
        S->stack[S->top]=x;    /* 将新结点插入栈顶 */
     S->top++;}
    return(S);  /* 插入成功则函数返回新栈顶指针 */
    }/* SEQSTACK_PUSH */
    datatype POP(seqstack *S)     
    { datatype x;       /* 保存栈顶元素数据值 */
    if  (EMPTY(S))                /* 检查顺序栈是否为空 */
    { printf("下溢错误! ");
    return(NULL);       /* 若删除失败返回0 */
    }
    else                          /* 若顺序栈非空删除之*/
    { S->top--;
    x=S->stack[S->top];    /* 暂存栈顶元素 */
    return (x);     
    }
    }/* SEQSTACK_POP */
    datatype    gettop_seqstack(seqstack *S)
    {  if  (EMPTY(S))
    {  printf("栈是空栈! ");
    return(NULL);    
    }
    else  return(S->stack[S->top]);
    }/* SEQSTACK_GETTOP */

    =======================================
    VC++需要对Main函数设置函数类型,此处可以设置为void
    ===========================================

    void main()       /* 从键盘输入一批正整数,然后按相反次序输出程序 */
    {
     int x, n=0;  /* x保留栈顶元素的数据值,n统计输入数据的个数 */

    ===================================
    在使用一个类指针之前需要分配内存
    ============================
     a= new seqstack;


     INITSTACK(a);   /* 将顺序栈初始化置空 */
     printf("\nPlease input data with 0 as a end:\n\n");
     scanf("%d", &x);  /* 输入第一个正整数 */
     while(x!=0)  /* 输入正整数,以-1作为结束标志 */
     { a=PUSH(a, x);  /* 将输入正整数顺序进栈 */
        n++;    scanf("%d", &x); } /* 继续输入下一个正整数 */
        printf("n=%d\n", n); /* 统计输入正整数的个数 */
        while(EMPTY(a)!=1) /* 若栈非空,则依次退栈输出整数 */
        { x=POP(a);  /* 将栈顶元素顺序出栈保存到x中 */
     printf("%d  ", x); /* 打印输出栈顶元素的数据值 */
     n--;  }
     printf("n=%d\n", n);       getchar();
    }/* MAIN */

    ----------------------------------------------
    越学越无知

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/4 21:02:00
     
     hinder 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(猛啃高等数学)
      文章:14
      积分:118
      门派:IEEE.ORG.CN
      注册:2007/9/24

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给hinder发送一个短消息 把hinder加入好友 查看hinder的个人资料 搜索hinder在『 C/C++编程思想 』的所有贴子 引用回复这个贴子 回复这个贴子 查看hinder的博客3
    发贴心情 
    感谢这位仁兄,但还是不能编译通过。另外 seqstack *a对 a早有定义了
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/4 22:11:00
     
     卷积内核 帅哥哟,离线,有人找我吗?
      
      
      威望:8
      头衔:总统
      等级:博士二年级(版主)
      文章:3942
      积分:27590
      门派:XML.ORG.CN
      注册:2004/7/21

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给卷积内核发送一个短消息 把卷积内核加入好友 查看卷积内核的个人资料 搜索卷积内核在『 C/C++编程思想 』的所有贴子 访问卷积内核的主页 引用回复这个贴子 回复这个贴子 查看卷积内核的博客4
    发贴心情 
    以下是引用hinder在2007-11-4 22:11:00的发言:
    感谢这位仁兄,但还是不能编译通过。另外 seqstack *a对 a早有定义了

    一分之千正解,编译及运行都没有问题啊。

    seqstack *a对 a早有定义,但没有分配空间,在VC中是不允许的,但C中可以运用时分配。

    ----------------------------------------------
    事业是国家的,荣誉是单位的,成绩是领导的,工资是老婆的,财产是孩子的,错误是自己的。

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/5 8:34:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 C/C++编程思想 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/14 7:12:27

    本主题贴数4,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    93.750ms