s[top++]和是[++top]是有区别的;看栈顶指针指向的如果指向栈顶元素,则top++再赋值
如果指向栈顶元素的下一个,则赋值再top++
/*s栈中的栈指针指向栈顶元素的下一个*/
#include<stdio.h>
#include<string.h>
void Hui_wen(char arr[],int n)
{
int top=1;
int mid=n/2-1,next;
char s[20];
int i,j;
for(i=0;i<=mid;i++)
{
s[top++]=arr[i];
}
if(n%2==0)
next=mid+1;
else
next=mid+2;
for(i=next;i<n&&top>1;i++)
{
if(s[--top]!=arr[i])
{
printf("%d ",top);
break;
}
}
if(top!=1)
{
printf("%d ",top);
printf("这不是一个回文字符串");
}
else
printf("这是一个回文字符串");
}
/*s栈中的栈指针指向栈顶元素*/
void Hui_wen1(char arr[],int n)
{
int top=0;
int mid=n/2-1,next;
char s[20];
int i,j;