数据结构:栈

一、概念

栈就是操作受限的线性表,只允许在一端进行操作的线性结构

特点:先进后出

把可以操作的一端叫做栈顶,不能操作的一端叫栈底

二、顺序栈

栈的顺序实现,仍然需要通过数组实现,除了数组之外,还需要一个栈顶元素对应的下标

三、功能

顺序栈的结构体

cs 复制代码
#ifndef __SEQ_STACk_H__
#define __SEQ_STACk_H__
#include <stdio.h>
#include <stdlib.h>
#define MAX 7
typedef int datatype;
typedef struct seq_stack{
	datatype data[MAX];
	int top;
}seq_stack,*seq_p;

//创建顺序桟
seq_p creat_stack();
//判空
int empty_stack(seq_p S);
//判满
int full_stack(seq_p S);
//入桟
void push_stack(seq_p S,datatype data);
//输出桟中的元素
void show_stack(seq_p S);
//出桟
void pop_stack(seq_p S);


#endif

1.创建顺序栈

cs 复制代码
seq_p creat_stack(){
	seq_p S=(seq_p)malloc(sizeof(seq_stack));
	if(S==NULL){
		printf("入参为空\n");
		return NULL;
	}
	S->top=-1;
	return S;
}

2.判空

cs 复制代码
int empty_stack(seq_p S){
		if(S==NULL){
		printf("入参为空\n");
		return -1;
	}
return S->top==-1?1:0;
}

3.判满

cs 复制代码
//判满
int full_stack(seq_p S){
		if(S==NULL){
		printf("入参为空\n");
		return -1;
		}
return S->top==MAX-1?1:0;
}

4.入栈

cs 复制代码
//入桟
void push_stack(seq_p S,datatype data){
	if(S==NULL){
		printf("入参为空\n");
		return;
		}
if(full_stack(S)){
		printf("桟满,不能插入\n");
		return;
		}
S->top++;//先加
S->data[S->top]=data;//再压入数值

}

5.遍历输出

cs 复制代码
//输出桟中的元素
void show_stack(seq_p S){
		if(S==NULL){
		printf("入参为空\n");
		return;
		}
		if(empty_stack(S)){
			printf("桟为空\n");
			return;
		}
//要保留桟的性质,只能从桟顶操作
for(int i=S->top;i>=0;i--){
	printf("%d ",S->data[i]);
}
}

6.出栈

cs 复制代码
//出桟
void pop_stack(seq_p S){
		if(S==NULL){
		printf("入参为空\n");
		return;
		}
		if(empty_stack(S)){
			printf("桟空\n");
			return;
		}
		printf("出桟的数值为%d\n",S->data[S->top]);
		S->top--;

}
相关推荐
嵌入式@秋刀鱼4 小时前
《第四章-筋骨淬炼》 C++修炼生涯笔记(基础篇)数组与函数
开发语言·数据结构·c++·笔记·算法·链表·visual studio code
嵌入式@秋刀鱼4 小时前
《第五章-心法进阶》 C++修炼生涯笔记(基础篇)指针与结构体⭐⭐⭐⭐⭐
c语言·开发语言·数据结构·c++·笔记·算法·visual studio code
泽02024 小时前
C++之list的自我实现
开发语言·数据结构·c++·算法·list
物联网嵌入式小冉学长7 小时前
2.线性表的链式存储-链表
数据结构·链表
顾小玙7 小时前
前缀和:leetcode974--和可被K整除的子数组
数据结构·算法
W说编程8 小时前
算法导论第三章:数据结构艺术与高效实现
c语言·数据结构·算法
hn小菜鸡8 小时前
LeetCode 2917.找出数组中的K-or值
数据结构·算法·leetcode
yield-bytes9 小时前
Java并发进阶系列:深度讨论高并发跳表数据结构ConcurrentSkipListMap的源代码实现(上)
数据结构
好易学·数据结构10 小时前
可视化图解算法51:寻找第K大(数组中的第K个最大的元素)
数据结构·python·算法·leetcode·力扣·牛客网·堆栈
NULL指向我11 小时前
C语言数据结构笔记5:Keil 编译器优化行为_malloc指针内存分配问题
c语言·数据结构·笔记