C语言实现出栈序列

本文实例为大家分享了C语言实现出栈序列的具体代码,供大家参考,具体内容如下

题目描述:

现在有一个1-n的排列,入栈序列已知,请给出字典序最大的出栈序列。

输入格式

第一行一个整数n。(1<=n<=100)
第二行n个整数,数据确保为1-n的排列。

输出格式

输出n个整数,既字典序最大的出栈序列。

输入样例

5
1 2 4 5 3

输出样例

5 4 3 2 1

解题思路:

1、获取当前数组的最大值,并且需要知道它的下标。所以定义了两个方法,getMax来获取数组的最大值maxNum,getMaxIndex获取最大值的下标max_index。

2、将最大值以及它前面的数字都压入到栈中去

3、这时候将最大值从栈中跳出来。(可要可不要,不要的话可以减少代码的冗余)

4、调用方法getMax,getMaxIndex来获取maxNum后面子数组的最大值r_max,以及下标。

5、将后面数组的最大值r_max和当前栈顶元素进行比较,如果栈顶元素大于等于r_max,那么将栈顶元素tmp从栈中跳出,同时将这个栈顶元素tmp输出。否则,如果r_max大于当前的栈顶元素,那么就将r_max之前的数字压入到栈中,同时需要获取r_max后面数组中的最大值以及下标。

注意这一步,必须是要将后面子数组的最大值r_max和栈顶元素进行比较。而不是拿后面子数组的最大值r_max和maxNum前面数字的最大值进行比较,这样的话,得到的就不是正确的出栈序列了。

6、重复上面的操作,直到将输入的数组已经遍历完了,程序结束。

对应的代码:

#include<stdio.h>
#define ERROR 0
#define OK 1
#define MAX_SIZE 100
#define N 100
typedef struct NODE{
    int arr[MAX_SIZE];
    int top;
}Node;
void init(Node &s){
   s.top = 0;
}
//压栈
int pushElem(Node &s,int c){
   if(s.top == MAX_SIZE){
     return ERROR;//如果栈满了,那么返回ERROR
   }
   s.arr[s.top++] = c;
   return OK;
}
//跳出栈顶元素
int popElem(Node &s,int &c){
   if(s.top == 0){
    /*
    如果栈为空,那么返回ERROR
    这里之所以是s.top == 0就为空,是因为下面进行删除操作
    的时候s.top是先减减的,所以在s.top = 1的时候,先进行减1操作,所以
    这时候s.top已经为0,表明我们已经删除了最后一个元素,再来进行这个操作的时候
    s.top为0,所以才用它来判断栈是否为空
    */
     return ERROR;
   }
   c = s.arr[--s.top];//将删除的元素赋值给c
   return OK;
}
//获取栈顶元素
int getTop(Node &s,int &c){
    if(s.top == 0){
    /*
    如果栈为空,那么返回ERROR
    这里之所以是s.top == 0就为空,是因为下面进行删除操作
    的时候s.top是先减减的,所以在s.top = 1的时候,先进行减1操作,所以
    这时候s.top已经为0,表明我们已经删除了最后一个元素,再来进行这个操作的时候
    s.top为0,所以才用它来判断栈是否为空
    */
     return ERROR;
   }
   c = s.arr[s.top - 1];//将栈顶元素赋值给c
   return OK;
}
int isEmpty(Node &s){
    return s.top == 0;
}
/*
将maxNum及其之前的数字压入栈中,同时返回maxNum的下标
*/
int getMax_index(int *arr,Node &s,int left,int right,int maxNum){
  int i;
  for(i = left; i < right; i++){
    pushElem(s,arr[i]);//将当前的数字压入栈中
    if(arr[i] == maxNum){
        //如果栈顶元素是最大值,那么就将退出循环遍历
        break;
    }
  }
  return i;
}
/*
获取left - right区间的最大值
*/
int arrayMax(int *arr,int left,int right){
  int i,maxNum = 0;
  for(i = left; i < right; i++){
    if(maxNum == 0 || arr[i] > maxNum)
        maxNum = arr[i];
  }
  return maxNum;
}
//获取最大的出栈序列
void getMax(int *arr,Node &s,int  left,int right,int maxNum){
  if(left >= right){
  //如果区间的范围不正确的时候,那么结束递归
     return;
  }
  //tmp表示栈顶元素,r_max表示maxNum后面子数组的最大值,i表示maxNum的下标
  int i,tmp,r_max;
  /*
  将maxNum及它前面的数字压入栈中,同时将maxNum的下标返回
  */
  i = getMax_index(arr,s,left,right,maxNum);
  r_max = arrayMax(arr,i + 1,right);//获取maxNum后面子数组的最大值
  /*
  这段代码也可以不写,因为下面会拿栈顶元素和r_max进行比较,所以
  maxNum是最大值,必然会先输出manNum的
  popElem(s,tmp);//将最大值maxNum赋值给tmp,并从栈中跳出
  printf("%d ",tmp);
  */
  while(!isEmpty(s)){
        getTop(s,tmp);//获取栈顶元素
        if(r_max > tmp){
           //判断r_max是否大于栈顶元素,如果是,将它及其之前的数字压入栈中,同时获取r_max的下标
            i = getMax_index(arr,s,i + 1,right,r_max);
            r_max = arrayMax(arr,i + 1,right);//获取 i + 1 到right区间的最大值
           // printf("\n右边最大值下标为:%d\n",i);
        }else{
        //如果r_max小于等于栈顶元素,那么就将栈顶元素从栈中跳出,并将其输出
           popElem(s,tmp);
           printf("%d ",tmp);
        }
  }
  getMax(arr,s,i + 1,right,r_max);
}
int main(){
  int arr[N];
  int n,i,maxNum;
  Node s;
  init(s);//初始栈
  printf("请输入栈的元素个数:");
  scanf("%d",&n);//输入栈元素个数
  for(i = 0; i < n; i++)
    scanf("%d",&arr[i]);
  maxNum = arrayMax(arr,0,n);//获取left-right区间的最大值
  getMax(arr,s,0,n,maxNum);
  return 0;
}

运行结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C语言实现出栈序列合法性判定

    本文实例为大家分享了C语言实现出栈序列合法性判定的具体代码,供大家参考,具体内容如下 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序. 假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列.(注意:这两个序列的长度是相等的) 输入格式 第一行一个整数n,表示输入序列的长度.(1<=n<=10000) 第二行n个整数,表示栈的压入顺

  • C语言实现出栈序列

    本文实例为大家分享了C语言实现出栈序列的具体代码,供大家参考,具体内容如下 题目描述: 现在有一个1-n的排列,入栈序列已知,请给出字典序最大的出栈序列. 输入格式 第一行一个整数n.(1<=n<=100) 第二行n个整数,数据确保为1-n的排列. 输出格式 输出n个整数,既字典序最大的出栈序列. 输入样例 5 1 2 4 5 3 输出样例 5 4 3 2 1 解题思路: 1.获取当前数组的最大值,并且需要知道它的下标.所以定义了两个方法,getMax来获取数组的最大值maxNum,getMa

  • C语言数据结构之栈简单操作

    C语言数据结构之栈简单操作 实验: 编写一个程序实现顺序栈的各种基本运算,并在此基础上设计一个主程序,完成如下功能: (1)初始化顺序栈 (2)插入元素 (3)删除栈顶元素 (4)取栈顶元素 (5)遍历顺序栈 (6)置空顺序栈 分析: 栈的顺序存储结构简称为顺序栈,它是运算受限的顺序表. 对于顺序栈,入栈时,首先判断栈是否为满,栈满的条件为:p->top= =MAXNUM-1,栈满时,不能入栈; 否则出现空间溢出,引起错误,这种现象称为上溢. 出栈和读栈顶元素操作,先判栈是否为空,为空时不能操作

  • C语言 表、栈和队列详解及实例代码

    C语言 表.栈和队列详解 表ADT 形如A1,A2,A3-An的表,这个表的大小为n,而大小为0的表称为空表,非空表中,Ai+1后继Ai,Ai-1前驱Ai,表ADT的相关操有PrintList打印表中的元素:CreateEmpty创建一个空表:Find返回关键字首次出现的位置:Insert和Delete从表的某个位置插入和删除某个关键字. 对表的所有操作都可以通过使用数组来实现,但在这里使用链表的方式来实现.链表(linked list)由一系列不必在内存中相连的结构组成,每个结构均含有元素和指

  • Java语言实现数据结构栈代码详解

    近来复习数据结构,自己动手实现了栈.栈是一种限制插入和删除只能在一个位置上的表.最基本的操作是进栈和出栈,因此,又被叫作"先进后出"表. 首先了解下栈的概念: 栈是限定仅在表头进行插入和删除操作的线性表.有时又叫LIFO(后进先出表).要搞清楚这个概念,首先要明白"栈"原来的意思,如此才能把握本质. "栈"者,存储货物或供旅客住宿的地方,可引申为仓库.中转站,所以引入到计算机领域里,就是指数据暂时存储的地方,所以才有进栈.出栈的说法. 实现方式是

  • 总结易语言节点与栈的操作方法

    以下就是本次我们给大家分享了易语言节点与栈的操作的实例代码和相关内容: .版本 2 .支持库 EDataStructure .程序集 窗口程序集1, , , 易语言节点与栈的操作 .子程序 _按钮1_被单击 .局部变量 栈, 栈 .局部变量 yyy, 节点 .局部变量 zzz, 节点 .局部变量 ttt, 节点 .局部变量 获取栈的节点信息1, 文本型 .局部变量 获取栈的节点信息2, 日期时间型 yyy.加入属性 ("姓名", "张三") yyy.加入属性 (&q

  • C语言实现链栈的步骤

    链栈图解 链栈的常规操作 /********************* 链栈的常规操作 ****************************/ LinkStack InitLinkStack(); // 初始化链栈 int StackEmpty(); // 判断链栈空 int StackLength(); // 求链栈长(链栈元素个数) int Push(); // 入栈 压栈 ElemType Pop(); // 出栈 弹栈 void DestroyStack(); // 销毁链栈 /**

  • C语言编程数据结构栈与队列的全面讲解示例教程

    目录 一.栈的表示和实现 1栈的概念和结构 2栈的初始化 3压栈(栈顶插入一个数据) 4出栈(栈顶删除一个数据) 5取栈顶元素 6取栈顶元素 7判断栈是否为空 二.队列的表示和实现 1队列的概念及结构 2队列的实现 3队列初始化 4入队(队尾插入一个数据) 5出队(队头删除一个数据) 6取队头数据 7取队尾数据 8计算队列中数据个数 9判断队列是否为空 10销毁队列 总结 一.栈的表示和实现 1栈的概念和结构 栈:一种特殊的线性表(逻辑上数据是连着放的),其只允许在固定的一端进行插入和删除操作.

  • C语言 浅谈栈与队列的定义与操作

    目录 栈的定义 栈的实现 前置 初始化栈 栈的销毁 栈的插入 出栈的操作 取栈顶元素 栈的大小 队列的定义 队列的基本操作 队列的初始化 队列的销毁 队列的插入 队列的删除 队列的判空 取出队头元素 取出队尾元素 队列的大小 栈的定义 栈同样是一种线性表,它的特性是插入元素必须从后面插入,删除元素也是从后面删除,进行数据删除和插入的一端称为栈顶,另一端是栈底. 压栈-就是插入元素 出栈-就是删除元素 它可以用数组实现也可以用链表实现 但是用数组实现更好,因为链表的插入和删除要进行遍历,而数组可以

  • C语言深入探究栈的原理

    栈 压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶. 出栈:栈的删除操作叫做出栈.出数据也在栈顶. 栈的实现 栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些.因为数组在尾上插入数据的 代价比较小.如下图: 下面用顺序表(数组)来实现栈: 建立一个顺序表结构: typedef int STDataType; typedef struct Stack { STDataType* a; int top; //表示栈顶 int capacity;//表示容量,当容量满时,扩容

随机推荐