zoukankan      html  css  js  c++  java
  • 简单数据结构之栈模拟

      1 /************************************************************************************** 
      2 * Function     : 模拟栈
      3 * Create Date  : 2014/04/23
      4 * Author       : NTSK13 
      5 * Email        : beijiwei@qq.com 
      6 * Copyright    : 欢迎大家和我一起交流学习,转载请保持源文件的完整性。 
      7 *                任何单位和个人不经本人允许不得用于商业用途 
      8 * Version      : V0.1                    
      9 ***************************************************************************************
     10 题目:简单数据结构之栈模拟
     11      
     12 **************************************************************************************/  
     13 #include<stdio.h>  
     14             
     18 #define M 10 //栈最大高度
     19 
     20 typedef struct stack
     21 {
     22     int data[M];
     23     int high;//栈当前高度
     24 }Stack;
     25 
     26 int sample[M];
     27 int result[M];
     28 
     29 void init_stack(Stack *a);//栈初始化
     30 int  push_stack(Stack *a,int value);//进栈
     31 int  pop_stack(Stack *a);//出栈
     32 int  get_top_element(Stack *a);//获取栈顶的元素
     33 
     34 // The first method:
     35 int main()  
     36 {  
     37     int i=0;
     38     Stack sq;
     39     init_stack(&sq);
     40 
     41     freopen("input.txt","r",stdin);
     42 
     43     for(i=0;i<M;i++) 
     44         scanf("%d",&sample[i]);  // get input data
     45     pop_stack(&sq);
     46     get_top_element(&sq);
     47            
     48     for(i=0;i<M;i++)
     49         push_stack(&sq,sample[i]);
     50     push_stack(&sq,100);
     51 
     52     for(i=0;i<M;i++)
     53         result[i]=pop_stack(&sq);
     54 
     55     for(i=0;i<M;i++)
     56     {
     57         printf("%d	",result[i]);
     58         fflush(stdout);//修复Eclipse printf()不能显示的小bug
     59     }
     60 
     61     printf("
    ");
     62     fflush(stdout);
     63 
     64     return (0);
     65 }  
     66 
     67 void init_stack(Stack *a)//栈初始化
     68 {
     69     (*a).high=0;
     70 }
     71 
     72 int  push_stack(Stack *a,int value)//进栈
     73 {
     74     if((*a).high==M)
     75     {
     76         printf("Stack is full, can not push !!! 
    ");
     77         fflush(stdout);
     78 
     79         return (-1);
     80     }
     81     else
     82     {
     83         if( (*a).high==0 )
     84         {
     85             (*a).data[0]=value;
     86             (*a).high++;
     87             return (1);
     88         }
     89         else
     90         {
     91             (*a).data[ (*a).high ]=value;
     92             (*a).high++;
     93             return (1);
     94         }
     95     }
     96 }
     97 
     98 int  pop_stack(Stack *a)//出栈
     99 {
    100     int tmp=0;
    101     if((*a).high==0)
    102     {
    103         printf("Stack is empty, can not pop !!! 
    ");
    104         fflush(stdout);
    105         return (-1);
    106     }
    107     else
    108     {
    109         tmp=(*a).data[ (*a).high -1];
    110         (*a).high--;
    111 
    112         return (tmp);
    113     }
    114 
    115 }
    116 int get_top_element(Stack *a)//获取栈顶的元素
    117 {
    118 
    119     int tmp=0;
    120     if((*a).high==0)
    121     {
    122         printf("Stack is empty, can not get top element !!! 
    ");
    123         fflush(stdout);
    124         return (-1);
    125     }
    126     else
    127     {
    128         tmp=(*a).data[ (*a).high -1];
    129         return (tmp);
    130     }
    131 
    132 }
    133     
    13
  • 相关阅读:
    国外插画等形式美术网址
    jquery对联广告
    国外优秀PS网站
    web前端开发工程师
    有关HTML+CSS需注意的一些问题
    公积金账户余额
    什么是CSS Float?
    5款影楼后期制作软件
    国外优秀设计网站推荐
    jQuery跟随屏幕滚动的层
  • 原文地址:https://www.cnblogs.com/ntsk13/p/3701420.html
Copyright © 2011-2022 走看看