人海一粒渣@705 2022-03-11 16:45 采纳率: 50%
浏览 96
已结题

写个算法判断给定的字符向量是否为回文

执行代码后段错误
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAXSIZE 20
typedef char ElemType;
typedef struct Stack
{
ElemType top;
ElemType base;
int Stacksize;
}Stack,StackLink;
//初始化一个栈
void InitalStack(StackLink S)
{
S->base=(ElemType
)malloc(MAXSIZE
sizeof(ElemType));
if(S->base==NULL)
printf("创建错误\n");
S->base=S->top;
S->Stacksize=MAXSIZE;
}
void Pop(StackLink S,ElemType e)
{
if(S->base==S->top)
printf("栈为空,出栈错误\n");
else
{
e=
--S->top;
}
}
void Push(StackLink S,ElemType e)
{
if(S->top-S->base==MAXSIZE)
printf("入栈错误\n");
else
{
*S->top++=e;
}
}
//判断空栈
int StackEmpty(StackLink S)
{
return(S->base==S->top);
}
int IsPlalindrome(ElemType *a)
{
StackLink S;
ElemType e;
InitalStack(S);
int len,i;
len=strlen(a);
//入栈
for(i=0;i<len/2;i++)
{
Push(S,a[i]);
}
//回文数的长度为奇数
if(len%2==1)
i++;
//将剩余的字符与栈中的字符进行比较,相同则出栈
while(!StackEmpty(S))
{
Pop(S,e);
if(e==a[i])
i++;
else
return 0;
}
return 1;
}
int main()
{
char a[MAXSIZE];
gets(a);
if(IsPlalindrome(a))
printf("YES\n");
else
printf("No\n");

return 0;

}

img

img

  • 写回答

3条回答 默认 最新

  • 关注

    代码修改如下:
    运行结果:

    img

    代码:

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #define MAXSIZE 20
    typedef char ElemType;
    typedef struct Stack
    {
        ElemType *top;
        ElemType *base;
        int Stacksize;
    }Stack,*StackLink;
    //初始化一个栈
    void InitalStack(StackLink S)
    {
        S->base=(ElemType*)malloc(MAXSIZE*sizeof(ElemType));
        if(S->base==NULL)
            printf("创建错误\n");
        S->top=S->base;//S->base=S->top;  //修改1
        S->Stacksize=MAXSIZE;
    }
    void Pop(StackLink S,ElemType *e)
    {
        if(S->base==S->top)
            printf("栈为空,出栈错误\n");
        else
        {
            --S->top;
            *e=*(S->top);
        }
    }
    void Push(StackLink S,ElemType e)
    {
        if(S->top-S->base==MAXSIZE)
            printf("入栈错误\n");
        else
        {
            *S->top++=e;
        }
    }
    //判断空栈
    int StackEmpty(StackLink S)
    {
        return(S->base==S->top);
    }
    int IsPlalindrome(ElemType *a)
    {
        StackLink S=(StackLink)malloc(sizeof(Stack)); //修改
        ElemType e;
        InitalStack(S);
        int len,i;
        len=strlen(a);
        //入栈
        for(i=0;i<len/2;i++)
        {
            Push(S,a[i]);
        }
        //回文数的长度为奇数
        if(len%2==1)
            i++;
        //将剩余的字符与栈中的字符进行比较,相同则出栈
        while(!StackEmpty(S))
        {
            Pop(S,&e);
            if(e==a[i])
                i++;
            else
            {
                free(S);//释放空间
                S = 0;
                return 0;
            }
        }
        free(S);//释放空间
        S = 0;
        return 1;
    }
    int main()
    {
        char a[MAXSIZE],*p;
        p = gets(a);//或者 p = gets_s(a);
        if(IsPlalindrome(a))
            printf("YES\n");
        else
            printf("No\n");
    
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月20日
  • 已采纳回答 3月12日
  • 创建了问题 3月11日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。