文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言实现出栈序列

2024-04-02 19:55

关注

本文实例为大家分享了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){
    
     return ERROR;
   }
   c = s.arr[--s.top];//将删除的元素赋值给c
   return OK;
}
//获取栈顶元素
int getTop(Node &s,int &c){
    if(s.top == 0){
    
     return ERROR;
   }
   c = s.arr[s.top - 1];//将栈顶元素赋值给c
   return OK;
}
int isEmpty(Node &s){
    return s.top == 0;
}

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;
}

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;
  
  i = getMax_index(arr,s,left,right,maxNum);
  r_max = arrayMax(arr,i + 1,right);//获取maxNum后面子数组的最大值
  
  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;
}

运行结果:

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯