标题:[求助]请教回文问题
只看楼主
sun99yue
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2007-3-10
 问题点数:0 回复次数:3 
[求助]请教回文问题
最后调试 总是不能得出结果 利用栈判断是否是回文
#include <stdio.h>
#include <malloc.h>
#include <string.h>
#include <math.h>
#define OK 1
#define ERROR 0
typedef int Status;
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
typedef int struct;
typedef struct
{char *base;
char *top;
char stacksize;
}SqStack;
Status InitStack(SqStack &s)
{
s.base=(char *)malloc(sizeof(char));
s.top=s.base;
s.stacksize=STACK_INIT_SIZE;
return OK;
}
Status 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) return ERROR;
(*s).top=(*s).base+(*s).stacksize;
(*s).stacksize+=STACKINCREMENT;
}
*((*s).top)++=e;
return OK;
}
Status pop(SqStack *s,char *e)
{
if((*s).base==(*s).top) return ERROR;
*e=*--(*s).top;
return OK;
}
Status StackEmpty(SqStack s)
{
if(s.base==s.top) return OK;
else return ERROR;
}
void main()
{char ch1[50],ch2[50],e;int i=0;SqStack s;
InitStack(s);
printf("请输入字符串:");
scanf("%s",ch1);
while(ch1[i]!='\0')
push(&s,ch1[i++]);
i=0;
while(!StackEmpty(s))
{pop(&s,&e); ch2[i++]=e;
}
/*for(i=0;i<n;i++)
if(ch1[i]=!ch2[i]) break;*/
if(!strcmp(ch1,ch2)) printf("输入的字符串是回文\n");
else printf("输入的字符串不是回文\n");

}

搜索更多相关主题的帖子: 回文 char define include base 
2007-04-14 19:24
pinglideyu
Rank: 3Rank: 3
来 自:武汉工程大学
等 级:论坛游侠
威 望:1
帖 子:735
专家分:140
注 册:2007-1-7
得分:0 
这个题我也想知道!
前些天老师讲过了的,可惜我忘记了。
哎 帮忙吧

~~我的明天我知道~~
2007-04-14 20:15
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
得分:0 

这么复杂.用了栈.

for(i=0;j=strlen(str)-1;i<j;i++,j--)
{
if(str[i]!=str[j])
{
return 0;
}
}
return 1;


倚天照海花无数,流水高山心自知。
2007-04-14 21:58
sun99yue
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2007-3-10
得分:0 

谢谢楼上的 我运行调试了 还是不能得出结果...

2007-04-15 11:05



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




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

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