当前位置: 首页 > article >正文

C语言数据结构学习:栈

C语言 数据结构学习 汇总入口:

C语言数据结构学习:[汇总]

1. 栈

  1. 栈,实际上是一种特殊的线性表。
  2. 这里使用的是链表栈,链表栈的博客:C语言数据结构学习:单链表

2. 栈的特点

  1. 只能在一端进行存取操作,导致存取的元素元素有先进后出的特点
  2. 栈是一种只能在一端进行插入和删除操作的特殊线性表。
  3. 后进先出(Last In First Out,LIFO)
    • 就像往一个桶里放东西再取东西一样,后放进去的东西会先被取出来。
  4. 基本操作
    • 入栈(push):将一个元素压入栈顶。例如,往栈里放一本书,这本书就成为了新的栈顶元素。
    • 出栈(pop):从栈顶取出一个元素。相当于从桌子上拿走最上面的那本书。
    • 读栈顶元素(peek):只查看栈顶元素的值而不取出它。如同看一下最上面那本书是什么,但不拿走它。

3. 代码示例

  1. 定义新的类型:Node,用于创建节点

    /* 定义新的类型Node,用于创建节点 */
    typedef struct Node {
    	int data;
    	struct Node* next;
    }Node;
    
  2. 初始化栈

    /* 初始化栈 */
    Node* initStack() {
    	Node* S = (Node*)malloc(sizeof(Node));
    	S->data = 0;
    	S->next = NULL;
    	return S;
    }
    
  3. 入栈(push)、出栈(pop)、读栈顶元素(peek)

    /* 出栈 */
    //判断栈是否为空
    int isEmpty(Node* S) {
    	if (S->data == 0 || S->next == NULL) {
    		return 1;
    	}
    	else{
    		return 0;
    	}
    }
    //出栈
    int pop(Node* S) {
    	if (isEmpty(S)) {
    		return -1;
    	}
    	else {
    		Node* current = S->next;	//获取第一个元素
    		int data = current->data;	//获取第一个元素的data
    		S->next = current->next;	//把栈头的next指向当前的next
    		free(current);				//释放当前
    		return data;				//返回data
    	}
    }
    
    /* 入栈 */
    void push(Node* S, int data) {
    	Node* node = (Node*)malloc(sizeof(Node));
    	node->data = data;
    	node->next = S->next;
    	S->next = node;
    	S->data++;
    }
    
    /* 读栈顶元素 */
    int peek(Node* S) {
    	if (isEmpty(S)) {
    		return -1;
    	}
    	else {
    		S->data--;
    		return S->next->data;
    	}
    }
    
  4. 打印栈

    /* 打印栈 */
    void printStack(Node* S) {
    	Node* current = S->next;
    	while (current){	//当前不为空则进入
    		printf("%d ", current->data);
    		current = current->next;
    	}
    	printf("NULL\\n");
    }
    
  5. 测试

    /* 测试 */
    int main(void)
    {
    	Node* S = initStack();
    	push(S, 1);
    	printStack(S);
    	push(S, 2);
    	printStack(S);
    	push(S, 3);
    	printStack(S);
    	push(S, 4);
    	printStack(S);
    	push(S, 5);
    	printStack(S);
    	
    	pop(S);
    	printStack(S);
    	pop(S);
    	printStack(S);
    	pop(S);
    	printStack(S);
    	pop(S);
    	printStack(S);
    	return 0;
    }
    


http://www.kler.cn/a/370941.html

相关文章:

  • JSON 文本的多层嵌套格式
  • 【Linux】常见指令(一)
  • 《数据思维》之数据可视化_读书笔记
  • RabbitMQ(三)
  • 大疆机场及无人机上云
  • linux mysql 备份
  • 力扣21 : 合并两个有序链表
  • Taro React-Native Android apk 打包
  • 群晖通过 Docker 安装 Firefox
  • 2024 年 MathorCup 数学应用挑战赛——大数据竞赛--赛道 B:电商品类货量预测及品类分仓规划
  • v4.7+版本用户充值在交易统计中计算双倍的问题修复
  • 【flink】之集成mybatis对mysql进行读写
  • WPF的行为(Behavior)
  • 【vs2022】windows可用的依赖预编译库
  • Nginx流量同时转发多后端(流量镜像分发)
  • WPF+MVVM案例实战(十一)- 环形进度条实现
  • Flink CDC系列之:学习理解核心概念——Data Sink
  • RCNN系列算法
  • ES、BOM 和 DOM
  • java-web-day6-下-知识点小结
  • Android性能优化之2个帧率和卡顿监控方案(附实现代码)
  • 【网页内嵌PDF下载】PDF.js妙用
  • MFC tcpclient
  • STM32主从定时器输出个数、频率可调的脉冲
  • 知名数字中国战略布局与新质生产力培训师讲师培训讲师唐兴通数字经济数字化转型专家教授学者大数据AIGC大模型智能化战略数字时代商业模式创新
  • Hana 到 PostgreSQL 数据迁移同步