数据结构实验之栈:行编辑器
来源:互联网 发布:阿里云远程桌面密码 编辑:程序博客网 时间:2024/04/29 16:21
数据结构实验之栈:行编辑器
Time Limit: 1000MS Memory limit: 65536K
题目描述
输入
输出
示例输入
whli##ilr#e(s#*s)outcha@putchar(*s=#++);
示例输出
while(*s)putchar(*s++);
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define stackmax 10000
#define stacknum 10000
typedef int elemtype;
typedef struct
{
elemtype *base;
elemtype *top;
int stacksize;
}sqstack;
int initstack(sqstack &s)
{
s.base = (elemtype *)malloc(stackmax * sizeof(elemtype));
if(!s.base) exit(0);
s.top = s.base;
s.stacksize = stackmax;
}
char push(sqstack &s, char e)
{
if(s.top - s.base > s.stacksize)
{
s.base = (elemtype *)realloc(s.base,(s.stacksize+stacknum) * sizeof(elemtype));
if(!s.base) exit(0);
s.top = s.base + s.stacksize;
s.stacksize += stacknum;
}
*s.top++=e;
}
int pop(sqstack &s)
{
if(s.top==s.base) return 0;
s.top--;
return 1;
}
int clearstack(sqstack &s)
{
s.top = s.base;
return 1;
}
int stackempty(sqstack &s)
{
if(s.top == s.base)
return 1;
else
return 0;
}
char editor(sqstack &s, char a[])
{
int n = strlen(a);
int i;
for(i=0; i<n; i++)
{
if(a[i]!='#'&&a[i]!='@')
{
push(s, a[i]);
}
if(a[i]=='#'&&!stackempty(s))
pop(s);
if(a[i]=='@'&&!stackempty(s))
clearstack(s);
}
}
void putstack(sqstack &s)
{
while(s.top > s.base)
{
printf("%c", *(s.base));
s.base++;
}
printf("\n");
}
int main()
{
char a[255];
sqstack s;
while(gets(a)!=NULL)
{
initstack(s);
editor(s, a);
putstack(s);
}
return 0;
}
- 数据结构实验之栈:行编辑器(栈)
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- SDUT1479数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 数据结构实验之栈:行编辑器
- 七牛-预转(缩略图)持久化(java)
- java 集合list和map的用法
- iOS歌词逐渐变色动画
- MySQL创建账户及授权
- Linux CFS调度器之队列操作--Linux进程的管理与调度(二十七)
- 数据结构实验之栈:行编辑器
- 算法学习(2):动态规划
- 树状数组的应用系列
- 对webservice 的理解 以及示例
- 实现苏宁易购大致框架和分类效果
- qq第三方登录问题
- Could not find Developer Disk Image
- 服务框架dubbo
- Codeforces103D Time to Raid Cowavans(分块+离线处理)