| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 399 人关注过本帖
标题:大侠们看一下这个程序哪里错了?
只看楼主 加入收藏
妙恋无瑕
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2011-4-26
结帖率:50%
收藏
已结贴  问题点数:5 回复次数:2 
大侠们看一下这个程序哪里错了?
typedef struct
{
    short int retAddr;/*标记返回时的位置*/
    int nParam;    /*参数n*/
    char fromParam;/*参数frompeg*/
    char auxParam;/*参数auxpeg*/
    char toParam;/*参数topeg*/
}Datatype;

#include<stdio.h>
#include"SeqStack.h"
#define MaxNum 20


void Simtowers(int n,char fromPeg,char auxPeg,char toPeg,SeqStack curr)
{
    DataType curr;/*当前工作区数据元素*/
    SeqStack s;/*模拟系统运行时栈的堆栈*/
    char temp;
    short int i;
    SSInitiate(&s);/**初始化堆栈S/


  /*当前工作区初始化、模仿主函数的第一次调用*/

curr.retAddr=1;
curr.nParam=n;
curr.fromParam=fromPeg;
curr.fromauxParam=auxPeg;
curr.fromttoParam=toPeg;
SSPush(&s,curr);/*当前工作区入栈*/

/*以下为模拟递归出口*/
start:
     if(curr.nParam==1)
     {
    printf("\n%s%c%s%c","Move Disk 1 from Peg",curr.fromParam,"toPeg",curr.toParam);
    i=curr.retAddr;
    SSPop(&s,&curr);/*出栈得到新的当前工作区数据元素*/
    switch(i)
    {
        case 1: goto lable1;
        case 2: goto lable2;
        case 3: goto lable3;

    }
     }

/*以下模拟递归自调用过程*/
SSPush(&s,curr);/*当前工作区数据元素入栈*/
curr.nParam--;
temp=curr.auxParam;
curr.auxParam=curr.toParam;
curr.toParam=temp;
curr.retAddr=2;
goto start;

/*以下模拟返回第一次递归调用*/
lable2:
      printf("\n%s%d%s%c%s%c","Move Disk",curr.nParam,"from Peg",curr.fromParam,"toPeg",curr.toParam);
      SSPush(&s,curr);/*当前工作区数据元素入栈*/
      curr.nParam--;
      temp=curr.fromParam;
      curr.fromParam=curr.auxParam;
      curr.auxParam=temp;
      curr.retAddr=3;
      goto start;

/*以下模拟返回第2次递归调用*/

lable3:
       i=curr.retAddr;
    SSPop(&s,&curr);/*出栈得到新的当前工作区数据元素*/
    switch(i)
    {
        case 1: goto lable1;
        case 2: goto lable2;
        case 3: goto lable3;

    }
    /*以下模拟返回主函数*/

lable1:
    return;
}

/*下面是调用的函数*/


#include<stdio.h>
#define MaxSize 100
typedef int DataType;
typedef struct
{
    DataType list[MaxSize];
    int top;
}SeqStack;

void SSInitiate(SeqStack *s)
{
    s->top=0;
}

int SSPush(SeqStack *s,DataType x)
{
    if(s->top>=MaxSize)
    {
        printf("队栈已满!\n");
        return 0;
    }
    else
    {
        s->list[s->top]=x;
        s->top++;
        return 1;
    }
}

int SSPop(SeqStack *s,DataType *d)
{
    if(s->top<=0)
    {
        printf("队栈已空无法出栈!\n");
        return 0;
    }
    else
    {
        s->top--;
        *d=s->list[s->top];
        return 1;
    }
}


int SSGetTop(SeqStack s,DataType *d)
{
    if(s.top<=0)
    {
    printf("队栈已空无法出栈!\n");
        return 0;
    }
    else
    {
        *d=s.list[s.top-1];
        return 1;
    }
}
搜索更多相关主题的帖子: 元素 
2011-04-26 23:07
voidx
Rank: 12Rank: 12Rank: 12
来 自:邯郸
等 级:火箭侠
帖 子:1250
专家分:3538
注 册:2011-4-7
收藏
得分:3 
终于看到有人用 goto ~
2011-04-26 23:09
MrBluer
Rank: 4
等 级:业余侠客
威 望:1
帖 子:120
专家分:263
注 册:2010-10-23
收藏
得分:3 
多好的goto语句啊,让我想起了老师的谆谆教导啊
2011-04-27 21:45
快速回复:大侠们看一下这个程序哪里错了?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025640 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved