判断栈的操作是否合法

该程序实现了一段字符串的对称性检查,通过创建和操作栈来完成。同时,它展示了如何在链表中进行元素的插入操作,并输出链表的长度。程序首先插入字符'x'、'z'、'y'、'z'和'x'到链表,然后检查链表的对称性,最后输出对称性的判断结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

P66第三题

#include <stdio.h>
#include <stdlib.h>

#define true 1
#define false 0

_Bool Judge(char str[],int  n)
{
    int  k=0,t=0;
    for(int i=0;i<n;i++)
    {
        switch(str[i])
        {
        case 'I':
            k++;
            break;
        case 'O':
            t++;
            if(t>k)  return false;
            break;
        default:
            break;
        }

    }
    if(k!=t) return false;
    return true;

}
int main()
{
    char str[6]={'I','O','I','I','O','O'};
    if(Judge(str,6))
    {
        printf("合法\n");
    }else
    {
        printf("不合法\n");
    }

    return 0;
}

第4题

#include <stdio.h>
#include <stdlib.h>

#define true 1
#define false 0

#define MaxSize 50
typedef  struct
{
    char data[MaxSize];
    int  top;
}SqStack;
void IninStack(SqStack *S)
{
    S->top=-1;
}
_Bool StackEmpty(SqStack *S)
{
    if(S->top==-1)
        return true;
    else
        return false;
}
_Bool Push(SqStack *S,char x)
{
    if(S->top==MaxSize-1)
        return false;
    S->data[++S->top]= x;
    return true;

}
_Bool Pop(SqStack *S,char * x)
{
    if(S->top==-1)
        return false;
    *x=S->data[S->top];
    S->top--;
    return true;
}
_Bool Top(SqStack *S,char * x)
{
    if(S->top==-1)
        return false;
    *x=S->data[S->top];
    return true;
}
typedef struct
{
    char data;
    struct LNode *next;
}LNode,*LinkList;
LNode *GetElem (LinkList L,int i)
{
    int j=1;
    LNode *p=L->next;
    if(i==0)
        return L;
    if(i<0)
        return NULL;
    while(p&&j<i)
    {
        p=p->next;
        j++;
    }
    return p;
}
_Bool LinkInsert(LinkList L,int i,char x)
{
    LNode *l=GetElem(L,i-1);
    LNode *in = (LNode *)malloc(sizeof(LNode));
    if(in==NULL)
        return false;
    in->data=x;
    in->next=l->next;
    l->next=in;
    return true;

}
int GetLength(LinkList L)
{
    int i=0;
    LNode * p = L->next;
    if(p==NULL)
        i=0;
    while(p)
    {

        i++;
        p=p->next;
    }
    return i;
}
int main()
{
    LinkList L=(LNode *)malloc(sizeof(LNode));
     L->next=NULL;;
    SqStack S;
    IninStack(&S);
    LinkInsert(L,1,'x');
    LinkInsert(L,2,'z');
    LinkInsert(L,3,'y');
    LinkInsert(L,4,'z');
    LinkInsert(L,5,'x');
    int length = GetLength(L);
     printf("%d\n",length);


    int  i=0,j=0;
    for( i=0;i<length/2;i++)
    {
        char temp=GetElem(L,i+1)->data;

       printf("%c\n",temp);
        Push(&S,temp);
    }
    LNode *ll;
    for(j=i;j<length;j++)
    {
        ll=GetElem(L,j+1);

        char temp=ll->data;
        char tt;
        Pop(&S,&tt);
        if(temp!=tt)
        {
            printf("不对称\n");
            break;
        }
        printf("对称\n");
    }


    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值