数据结构和算法学习记录——栈和队列作业(实现链栈上的进栈、实现链栈上的退栈、实现链队上的入队列)

简介: 数据结构和算法学习记录——栈和队列作业(实现链栈上的进栈、实现链栈上的退栈、实现链队上的入队列)

题目来自:《数据结构》大连理工大学出版社(2019.8第一版)

链栈上的进栈

代码实现

//链栈上的进栈
void Push(LstackTp* ls, DataType x) //采用头插的方式进行进栈的操作
{
  LstackTp* p = (LstackTp*)malloc(sizeof(LstackTp)); //创建一个新结点
  p->data = x;                                       //将新结点的数据域赋上相应的数据
  p->next = ls;                                      //将新结点的指针域指向头结点
  ls = p;                                            //最后将新结点作为头结点,进栈操作完成
}

思路图解

链栈上的退栈

代码实现

int Pop(LstackTp* ls, DataType x) //采用头删的方式进行退栈操作
{
  LstackTp* p;                  //创建一个临时结点p
  if (ls != NULL)               //判断ls是否为空,不为空才能进行退栈操作
  {
    p = ls;                   //用结点p来记录ls
    x = p->data;
    ls = ls->next;
    free(p);                  //释放p
    return 1;         //退栈成功返回1
  }
  else
  {
    return 0;                 //退栈失败返回0
  }
}

思路图解

 

链队上的入队列

代码实现

void EnQueue(QueptrTp* lq, DataType x)        
{
  LqueueTp* p;
  p = (LqueueTp*)malloc(sizeof(LqueueTp));   //创建新结点p
  p->data = x;               
  p->next = NULL;                            //初始化新结点
  (lq->rear)->next = p;                      //插入尾结点的下一个位置
  lq->rear = p;                              //将新结点设为新的尾结点
}

思路图解

目录
相关文章
|
15天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
90 9
|
11天前
|
算法 调度
基于遗传模拟退火混合优化算法的车间作业最优调度matlab仿真,输出甘特图
车间作业调度问题(JSSP)通过遗传算法(GA)和模拟退火算法(SA)优化多个作业在并行工作中心上的加工顺序和时间,以最小化总完成时间和机器闲置时间。MATLAB2022a版本运行测试,展示了有效性和可行性。核心程序采用作业列表表示法,结合遗传操作和模拟退火过程,提高算法性能。
|
18天前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
1月前
初步认识栈和队列
初步认识栈和队列
58 10
|
1月前
【数据结构】-- 栈和队列
【数据结构】-- 栈和队列
16 0
|
1月前
|
机器学习/深度学习 算法 数据处理
EM算法对人脸数据降维(机器学习作业06)
本文介绍了使用EM算法对人脸数据进行降维的机器学习作业。首先通过加载ORL人脸数据库,然后分别应用SVD_PCA、MLE_PCA及EM_PCA三种方法实现数据降维,并输出降维后的数据形状。此作业展示了不同PCA变种在人脸数据处理中的应用效果。
33 0
|
1月前
探索数据结构:队列的的实现与应用
探索数据结构:队列的的实现与应用
|
1月前
|
存储 C语言
栈和队列题目练习
栈和队列题目练习
16 0
|
6天前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
15 1
|
9天前
|
存储 算法 Java
数据结构的栈
栈作为一种简单而高效的数据结构,在计算机科学和软件开发中有着广泛的应用。通过合理地使用栈,可以有效地解决许多与数据存储和操作相关的问题。