#include <stdio.h>
#include<stdlib.h>
#define Max 100
char *top;
char *boton;
char *p;
void push(char m)
{
if(p>top)
{
printf("栈以满\n");
return;
}
else
{
p++;
*p=m;
}
}
void pop()
{
char q;
if(p<=boton)
{
printf("空栈\n");
return;
}
else
{
q=p;
p--;
free(q);
}
}
void main(void)
{
char *q,c;
p=(char *) malloc (Max*sizeof(char));
if(!p)
{
printf("内存分配失败\n");
return(1);
}
boton=p;
top=p+Max-1;
printf("请输入数据:\n");
while(1)
{
c=getchar();
if((p==boton)&&(c=='#'))
{continue;}
if((p!=boton)&&(c=='#'))
{
pop();
}
if(c=='\n')
{
break;
}
else
{
push(c);
}
}
q=boton;
printf("\n");
while(q<p)
{
q++;
printf("%c",*q);
}
}
该程序的功能原本是输入一串字符,如果遇到#就删除前一个字符,如输入aabbcc#ddee##fg#h,输出为aabbcddfh
请问该怎么解决。