#include <stdlib.h>
#include <stdio.h>
#include <malloc.h>
#include <string.h>
#include <conio.h>
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
struct SqStack
{
char *base;
char *top;
int stacksize;
};
void InitStack(SqStack &S)
{
S.base=(char*)malloc(STACK_INIT_SIZE *sizeof(char));
if (!S.base)
exit(1);
S.top=S.base;
S.stacksize=STACK_INIT_SIZE;
}
void push(SqStack &S,char e)
{
if(S.top-S.base>=S.stacksize)
{
S.base=(char*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(char));
if (!S.base)
exit(1);
S.top=S.base+S.stacksize;
S.stacksize+=STACKINCREMENT;
}
*S.top++=e;
}
char pop(SqStack &S,char &e)
{
if (S.top==S.base)
return false;
e=*--S.top;
return e;
}
void ClearStack(SqStack &S)
{
S.top=S.base;
}
void DestroyStack(SqStack &S)
{
free(S.base);
S.top=S.base;
}
bool StackEmpty(SqStack &S)
{
if (S.top==S.base)
return true;
return false;
}
void main()
{
char ch,e;
SqStack S,D;
InitStack(S);
InitStack(D);
ch=getchar();
while (ch!=EOF)
{
while(ch!=EOF&&ch!='\n')
{
switch(ch)
{
case'#':pop(S,e);break;
case'@':ClearStack(S);break;
default:push(S,ch);break;
}
ch=getchar();
}
while (!StackEmpty(S))
{
e=pop(S,e);
push (D,e);
}
--------------------Configuration: Cpp1 - Win32 Debug--------------------
Compiling...
Cpp1.cpp
C:\Users\lenovo\Desktop\Cpp1.cpp(81) : fatal error C1004: unexpected end of file found
執行 cl.exe 時出錯.
Cpp1.exe - 1 error(s), 0 warning(s)
uj5u.com熱心網友回復:
最前面加上 stdafx.h 或者檔案屬性中設定不使用預編譯頭uj5u.com熱心網友回復:
#include <stdlib.h>
#include <stdio.h>
#include <malloc.h>
#include <string.h>
#include <conio.h>
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
struct SqStack
{
char *base;
char *top;
int stacksize;
};
void InitStack(SqStack &S)
{
S.base=(char*)malloc(STACK_INIT_SIZE *sizeof(char));
if (!S.base)
exit(1);
S.top=S.base;
S.stacksize=STACK_INIT_SIZE;
}
void push(SqStack &S,char e)
{
if(S.top-S.base>=S.stacksize)
{
S.base=(char*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(char));
if (!S.base)
exit(1);
S.top=S.base+S.stacksize;
S.stacksize+=STACKINCREMENT;
}
*S.top++=e;
}
char pop(SqStack &S,char &e)
{
if (S.top==S.base)
return false;
e=*--S.top;
return e;
}
void ClearStack(SqStack &S)
{
S.top=S.base;
}
void DestroyStack(SqStack &S)
{
free(S.base);
S.top=S.base;
}
bool StackEmpty(SqStack &S)
{
if (S.top==S.base)
return true;
return false;
}
void main()
{
char ch,e;
SqStack S,D;
InitStack(S);
InitStack(D);
ch=getchar();
while (ch!=EOF)
{
while(ch!=EOF&&ch!='\n')
{
switch(ch)
{
case'#':pop(S,e);break;
case'@':ClearStack(S);break;
default:push(S,ch);break;
}
ch=getchar();
}
while (!StackEmpty(S))
{
e=pop(S,e);
push (D,e);
}
}
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/132504.html
標籤:圖形處理/算法
下一篇:如何用MFC做出圖形化界面
