数据结构之链栈的所有操作

2024-06-19 17:18

本文主要是介绍数据结构之链栈的所有操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>

typedef struct node
{
 struct node * next;
 int data;
}Node,*PNode;//定义节点类型

typedef struct stack
{
 PNode top;
 PNode bottom;
}Stack,*PStack;//定义栈类型。

void init_stack(PStack ps);
int isEmpty(PStack ps);
void push(PStack ps,int val);
void pop(PStack ps);
void traversal(PStack ps);

int main()
{
 PStack stack = (PStack) malloc(sizeof(Stack));
 init_stack(stack);
 isEmpty(stack);
 push(stack,1);
 push(stack,2);
 traversal(stack);
 pop(stack);
 push(stack,3);
 push(stack,4);
 traversal(stack);
 printf("%d\n",isEmpty(stack));
 return 0;
}

//初始化栈
void init_stack(PStack ps)
{
 PNode pnew =(PNode) malloc(sizeof(Node));
 if(pnew==NULL)
 {
  printf("初始化栈失败!\n");
  exit(-1);
 }
 printf("初始化栈开始:\n");
 ps->top=ps->bottom=pnew;
 pnew->next=NULL;
 printf("初始化栈成功!\n");
}

//判断栈是否为空
int isEmpty(PStack ps)
{
 if(ps->top==ps->bottom)
 {
  printf("栈为空!\n");
  return 1;
 }
 else
 {
  printf("栈不为为空!\n");
  return 0;
 }
}

//进栈
void push(PStack ps,int val)
{
 PNode pnew = (PNode) malloc(sizeof(Node));
 pnew->data = val;
 pnew->next = ps->top;
 ps->top = pnew;
 printf("进栈成功!\n");
}

//出栈
void pop(PStack ps)
{
 if(isEmpty(ps))
 {
  printf("栈为空!\n");
  exit(-1);
 }
 else
 {
  PNode pnew = ps->top;
  ps->top=ps->top->next;
  free(pnew);
  printf("出栈成功!\n");
 }
}

//遍历
void traversal(PStack ps)//传的是栈的地址,所以不能通过再定义一个栈变量来遍历(遍历的过程中实际上还是改变栈的值),
{
 /*PStack psn = ps;
 printf("栈遍历开始:\n");
 while(!isEmpty(psn))
 {
  printf("%d\n",psn->top->data);
  psn->top=psn->top->next;
 }
 printf("栈遍历结束:\n");**/
 PNode pnew = ps->top;
 printf("栈遍历开始:\n");
 while(pnew!=ps->bottom)
 {
  printf("%d\n",pnew->data);
  pnew=pnew->next; 
 }
 printf("栈遍历结束:\n");
}



这篇关于数据结构之链栈的所有操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1075651

相关文章

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字

MySQL——表操作

目录 一、创建表 二、查看表 2.1 查看表中某成员的数据 2.2 查看整个表中的表成员 2.3 查看创建表时的句柄 三、修改表 alter 3.1 重命名 rename 3.2 新增一列 add 3.3 更改列属性 modify 3.4 更改列名称 change 3.5 删除某列 上一篇博客介绍了库的操作,接下来来看一下表的相关操作。 一、创建表 create

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

封装MySQL操作时Where条件语句的组织

在对数据库进行封装的过程中,条件语句应该是相对难以处理的,毕竟条件语句太过于多样性。 条件语句大致分为以下几种: 1、单一条件,比如:where id = 1; 2、多个条件,相互间关系统一。比如:where id > 10 and age > 20 and score < 60; 3、多个条件,相互间关系不统一。比如:where (id > 10 OR age > 20) AND sco

PHP7扩展开发之流操作

前言 啥是流操作?简单来讲就是对一些文件,网络的IO操作。PHP已经把这些IO操作,封装成流操作。这节,我们将使用PHP扩展实现一个目录遍历的功能。PHP示例代码如下: <?phpfunction list_dir($dir) {if (is_dir($dir) === false) {return;} $dh = opendir($dir);if ($dh == false) {ret