标题:总觉得缺点什么?哪位大神可以帮个忙呀
取消只看楼主
应惜红颜
Rank: 2
等 级:论坛游民
帖 子:35
专家分:27
注 册:2018-5-20
结帖率:100%
已结贴  问题点数:20 回复次数:3 
总觉得缺点什么?哪位大神可以帮个忙呀
编程实现一个简单的行编辑功能:用户可以输入一行内容,并可进行简易编辑。要求:
(1)遇到输入部分内容有误时操作退格符“#”表示前一位无效;
(2)“@”表示之前的内容均无效。
不知道是在主函数中,还是LinkEdit这个函数中
终端这个怎么解释呢?这个会不会生成文件,怎么显示我输入的数据?有点混乱啊
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

//线性表的动态分配顺序存储结构
#define STACK_ININT_SIZE 100
#define STACKINCREMENT 10
#define TURE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2

typedef int Status;
typedef int SElemType;

typedef struct SqStack
{
    SElemType *base;
    SElemType *top;
    int stacksize;
}SqStack;
Status InitStack(SqStack *S);  //构造一个空的栈表
Status LinkEdit(SqStack S);//利用字符栈S从终端接收一行并送至调用过程的数据区
Status Pop(SqStack *S,SElemType e);//删除栈顶元素
Status Push(SqStack *S,SElemType e);//压栈
Status GetTop(SqStack S,SElemType e); //取出栈顶元素
Status DestoryStack(SqStack *S);//销毁栈
Status ClearStack(SqStack *S);//设置为空栈
Status StackTraverse(SqStack S,Status(*visit)(SElemType));//访问
Status copy(SElemType c);
int main()
{
    SqStack S;
    InitStack(&S);
    LinkEdit(S);
    return 0;
}
Status InitStack(SqStack *S)
{//构造一个空的栈
    (*S).base=(SElemType *)malloc(STACK_ININT_SIZE*sizeof(SElemType));//分配空间
    if(!(*S).base)
    {//空间分配失败
        exit(OVERFLOW);
    }
    (*S).top=(*S).base;
    (*S).stacksize=STACK_ININT_SIZE;
    return OK;   
}

Status LinkEdit(SqStack S)
{//利用字符栈S从终端接收一行并送至调用过程的数据区
    FILE * fp;
    char ch;
    char c;
    InitStack(&S);
    printf("请输入一个文本文件,^Z结束输入:\n");
    ch=getchar();
    while(ch!=EOF && ch!='\n')
    {//EOF为^Z键,全文结束符
        switch(ch)
        {
            case '#':
                Pop(&S,c);//出栈
                break;
            case '@':
                ClearStack(&S);//重置S为空栈
                break;
            default:Push(&S,ch);//压栈
        }
        ch=getchar();
    }
    StackTraverse(S,copy);//将从栈底到栈顶的站内字符传送至文件
    ClearStack(&S);//重置S为空栈
    fputc('\n',fp);
    if(ch!=EOF)
    {
        ch=getchar();
    }
    DestoryStack(&S);
}

Status Pop(SqStack *S,SElemType e)
{//删除栈顶元素 ,并用e返回该值
    if((*S).top==(*S).base)
    {//空栈
        return ERROR;
    }
    e=*--(*S).top;
    return OK;
}

Status Push(SqStack *S,SElemType e)//压栈
{
    if((*S).top-(*S).base>=(*S).stacksize)
    {//栈满
        (*S).base=(SElemType *)realloc((*S).base,((*S).stacksize+STACKINCREMENT)*sizeof(SElemType));// base的新地址
    if(!(*S).base)//分配失败
        exit(OVERFLOW);
    (*S).top=(*S).base+(*S).stacksize;//top的新地址
    (*S).stacksize+=STACKINCREMENT;
    }
    *((*S)).top++=e;
}
Status GetTop(SqStack S,SElemType e) //取出栈顶元素
{
    if(S.top==S.base)
    {//空栈
        return ERROR;
    }
    e=*(S.top-1);
    return OK;
}

Status DestoryStack(SqStack *S)//销毁栈
{
    free((*S).base);
    (*S).base=NULL;
    (*S).top=NULL;
    (*S).stacksize=0;
    return OK;
}

Status ClearStack(SqStack *S)//设置为空栈
{
    (*S).top=(*S).base;
    return OK;
}
Status StackTraverse(SqStack S,Status(*visit)(SElemType))//访问
{
    while(S.top>S.base)
    {
        visit(*S.base++);
    }
    printf("\n");
    return OK;
}

Status copy(SElemType c)
{//将字符e送至fp所指的文件中
    FILE *fp;
    fputc(c,fp);
    return OK;
}
搜索更多相关主题的帖子: Status base top  return 
2018-11-03 17:46
应惜红颜
Rank: 2
等 级:论坛游民
帖 子:35
专家分:27
注 册:2018-5-20
得分:0 
回复 2楼 豆豆的滴
是的,但是是在输入#或@后的,这种是回到文件里吗?
还是说我应该写点东西把栈里面的数据显示出来??

嶙峋
2018-11-03 22:58
应惜红颜
Rank: 2
等 级:论坛游民
帖 子:35
专家分:27
注 册:2018-5-20
得分:0 
回复 4楼 幻紫灵心
谢谢你的回答,但是有还是有很多不明白的地方?你可以再帮忙看一下吗?
Status copy(SElemType e)这个函数是不是需要一个txt文件呢?这点我不是很明白,你说终端是黑框框,那么我们数据写入的文件是什么?
就是在最后运行结果的时候,我输入一串字符,后面要做的事情我就不是很明白了。StackTraverse这个函数在InikEdit中是用了的吧。
嗯,那个Pop函数的SElemType中还要加一个*,形参的问题

嶙峋
2018-11-04 11:31
应惜红颜
Rank: 2
等 级:论坛游民
帖 子:35
专家分:27
注 册:2018-5-20
得分:0 
回复 7楼 幻紫灵心
谢谢哈,我后面改了一下,没用这些函数,直接用的黑框框
不过会再回去看一下的,希望有问题还可以在问你,嘿嘿
期待你的回答

嶙峋
2018-11-04 22:09



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-490962-1-1.html




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

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