zoukankan      html  css  js  c++  java
  • 栈的应用_回文字符的判定

    stack.h

    #ifndef stack_h__
    #define stack_h__
    
    #include <stdio.h>
    #include <malloc.h>
    #include <stdlib.h>
    
    enum boolean{FALSE, TRUE};
    typedef enum boolean BOOL;
    typedef int ElementType;
    typedef struct stack_def{
        ElementType* data;
        int top;
        int sz;
        int length;
    }stack;
    void initStack(stack* s, int sz);
    BOOL isEmpty(stack s);
    BOOL isFull(stack s);
    BOOL Pop(stack* s);
    BOOL Push(stack* s, ElementType e);
    ElementType getTop(stack s);
    void destoryStack(stack* s);
    #endif // stack_h__

    stack.c

    #include "stack.h"
    
    void initStack(stack* s, int sz){
        if (sz < 0){
            puts("sz < 0");
        }
        else{
            s->top = -1;
            s->sz = sz;
            s->length = 0;
            s->data  = (ElementType*)malloc(sizeof(ElementType)*s->sz);
            if (s->data == NULL)
                puts("s->data == NULL");
        }
    }
    
    BOOL isEmpty(stack s){
        return(BOOL)(s.length==0);
    }
    
    BOOL isFull(stack s){
        return(BOOL)(s.length==s.sz);
    }
    BOOL Pop(stack* s){                             // 出栈,并不返回此元素值
        if (isEmpty(*s)){
            return FALSE;
        }
        s->top--;
        s->length--;
    }
    
    BOOL Push(stack* s, ElementType e){         // 入栈
        if (isFull(*s)){
            return FALSE;
        }
        s->data[++s->top] = e;
        s->length++;
        return TRUE;
    }
    
    ElementType getTop(stack s){
        if (isEmpty(s)){
            puts("stack s  is empty.");
            exit(1);
        }
    
        return s.data[s.top];
    }
    void destoryStack(stack* s){
        free(s->data);
    }

    main.c

    #include  "stack.h"
    #include <string.h>
    
    int isSpecalStr(char *str, int str_len){                //判断是否为回文字符串
        stack s1, s2, tmp;
        int i, ret = 1;
        ElementType e;
    
        initStack(&s1, str_len/2);
        initStack(&s2, str_len/2);
        initStack(&tmp, str_len/2);
    
        for (i=0; i<str_len/2; i++){
            Push(&s1, str[i]);
            Push(&tmp, str[i+str_len/2]);
        }
        while (!isEmpty(tmp)){
            Push(&s2, getTop(tmp));
            Pop(&tmp);
        }// end while
    
        while (!isEmpty(s1) && !isEmpty(s2)){
            if (getTop(s1) != getTop(s2)){
                ret = 0; break;
            }
            Pop(&s1); Pop(&s2);
        }// end while 
    
        destoryStack(&s1);
        destoryStack(&s2);
        destoryStack(&tmp);
        return ret;
    }
    
    
    int main(){
        char str[50];
        stack s;
        int len ;
        initStack(&s, 50);
        printf("输入一个字符串:");
        gets(str);
        len = strlen(str);
        if (isSpecalStr(str, len))
            puts("YES");
        else
            puts("NO");
        return 0;
    }

    运行结果:
    结果1
    结果2
    结果3

  • 相关阅读:
    召开演示会议和总结会议
    召开每天的站立会议
    禅道管理中的项目管理--组织进行任务分解
    linux sort,uniq,cut,wc命令详解
    json2.js的用途(拯救IE)
    memcache的内存回收机制
    memcache内存分配机制
    Linux之Sed命令详解(总结一些实用例子)
    CentOS 设置网络(修改IP&修改网关&修改DNS)--update.14.08.15
    php中文字符串翻转
  • 原文地址:https://www.cnblogs.com/laohaozi/p/12538397.html
Copyright © 2011-2022 走看看