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

数据结构——lesson5栈和队列详解

hellohello~这里是土土数据结构学习笔记🥳🥳
在这里插入图片描述

💥个人主页:大耳朵土土垚的博客
💥 所属专栏:数据结构学习笔记
💥对于顺序表链表有疑问的都可以在上面数据结构的专栏进行学习哦~感谢大家的观看与支持🌹🌹🌹
有问题可以写在评论区或者私信我哦~

前言:

之前的博客我们学习了数据结构中的顺序表和链表,现在我们一起回顾一下它们各自的优缺点。
首先是顺序表
✨优点:
1.支持下标的随机访问(因为是数组的形式);
2.尾插尾删比较方便,效率不错;
3.CPU高速缓存命中率较高;
✨ 缺点:
1.前面部分插入删除数据需要挪动数据,时间复杂度为O(n);
2.空间不够需要扩容——一方面扩容需要付出代价例如异地扩容, 另一方面扩容一般还伴随着空间的浪费;
其次是链表
✨优点:
1.任意位置插入删除数据都比较方便高效,时间复杂度为O(1);
2.按需申请释放空间
✨缺点:
1.不支持下标的随机访问;
2.CPU高速缓存命中率较低;
我们发现顺序表的优点和缺点恰好对应着链表的缺点和优点,顺序表和链表各自都有它们独特的作用与优势,不存在优劣之分。大家在使用的时候要根据自己的需求去选择哦~


一、栈


1.1栈的概念及结构

栈: 一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。

压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。
出栈:栈的删除操作叫做出栈。出数据也在栈顶。

1.2栈的实现

栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些。因为数组在尾上插入数据的代价比较小。

在这里插入图片描述

如图所示,左边是栈尾,右边是栈顶(进行出栈也就是删除操作);
以下是栈的实现:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<stdbool.h>typedef int STDataType;// 支持动态增长的栈
typedef int STDataType;
typedef struct Stack//定义一个结构体表现栈
{STDataType* a;int top;       // 栈顶int capacity;  // 容量 
}Stack;
// 初始化栈 
void StackInit(Stack* ps);
// 入栈 
void StackPush(Stack* ps, STDataType data);
// 出栈 
void StackPop(Stack* ps);
// 获取栈顶元素 
STDataType StackTop(Stack* ps);
// 获取栈中有效元素个数 
int StackSize(Stack* ps);
// 检测栈是否为空,如果为空返回true,如果不为空返回false
bool StackEmpty(Stack* ps);
// 销毁栈 
void StackDestroy(Stack* ps);

栈实现包括初始化,入栈,出栈,获取栈顶元素,获取栈中有效元素个数,判断栈是否为空以及销毁栈这7个函数。

下面我们来具体实现栈:

(1)初始化栈

void StackInit(Stack* ps);

// 初始化栈 
void StackInit(Stack* ps)
{assert(ps);ps->a = NULL;ps->capacity = 0;ps->top = 0;//指向栈顶的下一个数据//ps->top = -1; //则指向栈顶数据
}

这里要注意ps->top = 0 代表的是栈顶元素的下一个;ps->top = -1才指向栈顶元素,因为后面的函数每增加一个元素,ps->top++,如果初始化top = 0,加一个元素后,top=1;表示的位置是下标为1(其本质是数组,下标为1的位置表示第二个元素),但确间接表明了栈中元素的个数刚好为1,所以为了后续方便,我们选择初始化top=0;当然你也可以自由选择。

(2)入栈

void StackPush(Stack* ps, STDataType data);

void StackPush(Stack* ps, STDataType data)
{assert(ps);if (ps->top == ps->capacity)//判断空间是否满了{//空间capacity满了就需要扩容STDataType newcapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;//判断是否扩容过,如果capacity为0就增加4//个单位空间,否则开辟capacity的2倍空间ps->capacity = newcapacity;//扩容后capacity要等于newcapacityps->a = (STDataType*)realloc(ps->a, newcapacity * sizeof(STDataType));if (ps->a == NULL){perror("realloc fail");return;}}ps->a[ps->top] = data;//入栈ps->top++;//栈顶+1}

这里入栈要注意判断栈的容量是否满了,满了需要使用realloc函数扩容,对于realloc函数有疑问的小伙伴可以查看土土的博客——C语言动态内存函数介绍

(3)出栈

void StackPop(Stack* ps)

// 出栈 
void StackPop(Stack* ps)
{assert(ps);assert(!StackEmpty(ps));//判断非空ps->top--;
}

出栈就比较简单,只需将top–即可,但是同时也要注意判断栈不为空哦~判空函数StackEmpty(ps)将在后面实现

(4)获取栈顶元素

STDataType StackTop(Stack* ps)

// 获取栈顶元素 
STDataType StackTop(Stack* ps)
{assert(ps);assert(!StackEmpty(ps));//判断非空return ps->a[ps->top-1];
}

是时候考验你们的专注力了,这里返回栈顶元素用的是top-1;有小伙伴知道为什么不直接用top吗?答案我们放在下一个获取栈中有效元素个数函数中揭晓。

(5)获取栈中有效元素个数

int StackSize(Stack* ps)

// 获取栈中有效元素个数 
int StackSize(Stack* ps)
{assert(ps);return ps->top;
}

上一个函数获取栈顶元素我们使用的是top-1,是因为在初始化函数时我们就介绍过将top初始化为0,指向栈顶元素的下一个,所以要获取栈顶元素我们要将top-1;依此类推栈中有效元素个数就恰好是top了。

(6)检测栈是否为空

bool StackEmpty(Stack* ps)

// 检测栈是否为空,如果为空返回true,如果不为空返回false
bool StackEmpty(Stack* ps)
{assert(ps);/*if (ps->top == 0)return true;elsereturn false;*/return ps->top == 0;
}

这里可以使用if语句来判断,也可以如上面代码所示直接使用return返回。

(7)销毁栈

void StackDestroy(Stack* ps)

// 销毁栈 
void StackDestroy(Stack* ps)
{assert(ps);free(ps->a);ps->capacity = 0;ps->a = NULL;ps->top = 0;
}

这里就不过多赘述,使用free销毁即可;因为数组时地址连续的一段物理空间,所以只要数组首元素地址即可free整个数组与链表需要遍历不同。

栈实现可视化如下图所示:

在这里插入图片描述
代码如下:

#define _CRT_SECURE_NO_WARNINGS 1
#include"stack.h"
void Sttest()
{Stack ST;StackInit(&ST);StackPush(&ST, 1);StackPush(&ST, 2);StackPush(&ST, 3);StackPush(&ST, 4);while (ST.top)//打印栈{printf("%d", StackTop(&ST));StackPop(&ST);//打印一个出一个}StackDestroy(&ST);}
int main()
{Sttest();return 0;
}

二、队列

2.1队列的概念及结构

队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out)
入队列:进行插入操作的一端称为队尾
出队列:进行删除操作的一端称为队头

发现进行删除操作的都是队头,无论栈还是队列;
队列根据其名字,我们不难发现类似于我们生活中的排队,先排队的肯定会先出去;
在这里插入图片描述

2.2队列的实现

队列也可以数组和链表的结构实现,使用链表的结构实现更优一些,因为如果使用数组的结构,出队列在数组头上出数据,效率会比较低。

// 链式结构:表示队列 
typedef int QDataType;
typedef struct QListNode 
{ struct QListNode* pNext; QDataType data; 
}QNode; // 队列的结构 
typedef struct Queue 
{ 
QNode* front; 
QNode* rear; 
}Queue; 
// 初始化队列 
void QueueInit(Queue* q); 
// 队尾入队列 
void QueuePush(Queue* q, QDataType data); 
// 队头出队列 
void QueuePop(Queue* q); 
// 获取队列头部元素 
QDataType QueueFront(Queue* q); 
// 获取队列队尾元素 
QDataType QueueBack(Queue* q); 
// 获取队列中有效元素个数 
int QueueSize(Queue* q); 
// 检测队列是否为空,如果为空返回非零结果,如果非空返回0 
int QueueEmpty(Queue* q); 
// 销毁队列 
void QueueDestroy(Queue* q);

队列相较于栈定义了两个结构体来表示,一个结构体QNode表示节点,另一个结构体Queue则用来表示队列的头尾指针,展示队列的结构。
队列也包含了初始化,队尾入队列,队头出队列,获取队列头部元素,获取队列尾部元素,以及有效元素个数,判空,销毁这八个函数。

(1)初始化队列

void QueueInit(Queue* q);

// 初始化队列 
void QueueInit(Queue* q)
{assert(q);q->front = NULL;q->rear = NULL;
}

将Queue结构体初始化即可

(2)队尾入队列

void QueuePush(Queue* q, QDataType data);

// 队尾入队列 
void QueuePush(Queue* q, QDataType data)
{assert(q);QNode* newnode = (QNode*)malloc(sizeof(QNode));//创建新节点if (newnode == NULL){perror("malloc fail");return;}newnode->data = data;newnode->pNext = NULL;//队列为空的情况入队列if (QueueEmpty(q)){q->front = newnode;q->rear = newnode;return;}//队列不为空的情况入队列else{q->rear->pNext = newnode;q->rear = newnode;return;}
}

队尾入队列首先要记得malloc一个新节点,然后要记得判断队列是否为空,分为两种情况。判空函数将在后面实现。

(3)队头出队列

void QueuePop(Queue* q);

// 队头出队列 
void QueuePop(Queue* q)
{assert(q);assert(!QueueEmpty(q));//判断队列非空QNode* tmp = q->front;//先保存队头指针q->front = tmp->pNext;free(tmp);
}

队头出队列要记得free释放出去节点的空间。

(4)获取队列头部元素

QDataType QueueFront(Queue* q);

// 获取队列头部元素 
QDataType QueueFront(Queue* q)
{assert(q);assert(!QueueEmpty(q));//判断队列非空return q->front->data;}

通过结构体Queue的front指针可以直接找到头返回即可。

(5)获取队列队尾元素

QDataType QueueBack(Queue* q);

// 获取队列队尾元素 
QDataType QueueBack(Queue* q)
{assert(q);assert(!QueueEmpty(q));//判断队列非空return q->rear->data;
}

同样通过结构体Queue的rear指针可以直接找到尾返回即可。

(6) 获取队列中有效元素个数

int QueueSize(Queue* q)

// 获取队列中有效元素个数 
int QueueSize(Queue* q)
{assert(q);assert(!QueueEmpty(q));//判断队列非空int count = 0;//记录元素个数QNode* cur = q->front;while (cur){cur = cur->pNext;count++;}return count;
}

这里队列用的是链表的结构,所以需要使用循环遍历来获取有效元素的个数。

(7)检测队列是否为空

bool QueueEmpty(Queue* q);

// 检测队列是否为空,如果为空返回true,非空返回false
bool QueueEmpty(Queue* q)
{assert(q);return q->front == NULL;}

队列头指针为空即没有元素进入队列。

(8)销毁队列

void QueueDestroy(Queue* q);

// 销毁队列 
void QueueDestroy(Queue* q)
{assert(q);while (q->front){QueuePop(q);}
}

QueuePop()函数将元素从队头删除的同时也使用了free释放空间,所以这里直接使用该函数即可。

队列实现可视化如下图所示:

在这里插入图片描述
实现代码如下:

#include"queue.h"void Qtest()
{Queue QT;QueueInit(&QT);QueuePush(&QT, 1);QueuePush(&QT, 2);QueuePush(&QT, 3);QueuePush(&QT, 4);while (QT.front){printf("%d", QueueFront(&QT));QueuePop(&QT);}QueueDestroy(&QT);
}
int main()
{Qtest();return 0;
}

三、练习题

1.一个栈的初始状态为空。现将元素1、2、3、4、5、A、B、C、D、E依次入栈,然后再依次出栈,则元素出
栈的顺序是(  )。
A 12345ABCDEB EDCBA54321C ABCDE12345D 54321EDCBA2.若进栈序列为 1,2,3,4 ,进栈过程中可以出栈,则下列不可能的一个出栈序列是()
A 1,4,3,2B 2,3,4,1C 3,1,4,2D 3,4,2,13.以下(  )不是队列的基本运算?
A 从队尾插入一个新元素
B 从队列中删除第i个元素
C 判断一个队列是否为空
D 读取队头元素的值

答案:BCB

四、结语

栈和队列有很多的相似之处,尽管栈是队头进入删除数据(后进先出),队列是队尾入数据,队头删数据(先进后出),但其本质是一样的。熟悉了栈和队列后,相信大家对于顺序表和链表的理解也会更上一层楼。以上就是栈和队列的学习啦~ 完结撒花~🥳🥳🎉

相关文章:

数据结构——lesson5栈和队列详解

hellohello~这里是土土数据结构学习笔记&#x1f973;&#x1f973; &#x1f4a5;个人主页&#xff1a;大耳朵土土垚的博客 &#x1f4a5; 所属专栏&#xff1a;数据结构学习笔记 &#x1f4a5;对于顺序表链表有疑问的都可以在上面数据结构的专栏进行学习哦~感谢大家的观看与…...

使用rsync同步服务器和客户端的文件夹

使用rsync同步服务器和客户端的文件夹 实现目的实验准备实验操作步骤服务器操作关闭防火墙和SELINUX安装rsync修改服务器配置文件/etc/rsync.conf创建服务器备份文件的目录创建rsync系统运行的用户修改备份文件的所有者和所属组创建rsync.passwd启动rsync服务并进行验证 客户端…...

计算机网络|Socket

文章目录 Socket并发socket Socket Socket是一种工作在TCP/IP协议栈上的API。 端口用于区分不同应用&#xff0c;IP地址用于区分不同主机。 以下是某一个服务器的socket代码。 其中with是python中的一个语法糖&#xff0c;代表当代码块离开with时&#xff0c;自动对s进行销毁…...

Python 使用 MyHDL库 实现FPGA板卡仿真验证

要使用 Python 结合 MyHDL 库实现 FPGA 板卡的仿真验证&#xff0c;您可以利用 MyHDL 提供的硬件描述语言和仿真功能来进行 FPGA 设计的验证。下面我将为您介绍一个简单的示例&#xff0c;演示如何使用 MyHDL 库进行 FPGA 设计的仿真验证。 步骤概述 编写 MyHDL 硬件描述&…...

解决SpringBoot集成WebSocket打包失败问题

前言 这几天在一个SpringBoot项目中使用WebSocket来用作客服聊天以及上传文件功能,项目在写的时候,以及在idea中跑的时候都非常完美,结果一打成jar包是,报错.在网上查了报错原因,原来是自己导入的WebSocket的jar与SpringBoot内置tomcat中的WebSocket的jar冲突,需要在打包时把S…...

i-vista五星测试标准

智能行车板块以八类场景评测汽车的 单车道纵向控制能力、 单车道横向控制能力、 单车道纵横向组合控制能力及换道辅助能力&#xff0c; 8类场景包括目标车静止、目标车低速、目标车减速、前车切入&#xff08;新增场景&#xff09;、直道居中行驶、直道驶入弯道、盲区无车、盲…...

初识Maven

介绍&#xff1a; web后端开发技术ApacheMaven是一个项目管理和构建工具&#xff0c;它基于项目对象模型&#xff08;POM&#xff09;的概念&#xff0c;通过一小段描述信息来管理项目的构建。安装&#xff1a;http://maven.apache.org/ Apache软件基金会&#xff0c;成立于19…...

16 Educational Codeforces Round 142 (Rated for Div. 2)C. Min Max Sort(递归、思维、dp)

C. Min Max Sort 很不错的一道题目&#xff0c;不过脑电波和出题人每对上&#xff0c; q w q 。 qwq。 qwq。 正难则反。 我们考虑最后一步是怎么操作的。 最后一步一定是对 1 1 1和 n n n进行操作 那么上一步呢&#xff1f; 上一步应该是对 2 2 2和 n − 1 n-1 n−1 以此类推…...

Mongodb安装配置

Mongodb安装配置 一、MongoDB简介二、Windows下MongoDB安装2.1.MongoDB下载2.2.安装MongoDB【解压版】2.2.1.解压2.2.2.创建和 bin 目录同级 data\db 目录来存储 MongoDB 产生的数据2.2.3.进入 bin 目录&#xff0c;cmd命令行窗口&#xff0c;使用命令的指定存储数据文件的形式…...

Linux常用操作命令大全

Linux常用操作命令大全 Linux,作为一款开源的操作系统,深受全世界开发者和系统管理员的喜爱。在Linux环境下,用户通过命令行界面可以执行各种操作,从而实现对系统的全面控制。本文将详细介绍Linux中常用的操作命令,帮助读者更好地理解和运用这些命令。 一、文件操作命令…...

CVPR2023 | 提升图像去噪网络的泛化性,港科大上海AILab提出 MaskedDenoising,已开源!

作者 | 顾津锦 首发 | AIWalker 链接 | https://mp.weixin.qq.com/s/o4D4mNM3jL6sYuhUC6VgoQ 当前深度去噪网络存在泛化能力差的情况&#xff0c;例如&#xff0c;当训练集噪声类型和测试集噪声类型不一致时&#xff0c;模型的性能会大打折扣。作者认为其原因在于网络倾向于过度…...

[python] dict类型变量写在文件中

在Python中&#xff0c;如果你想要将一个字典变量以具有可读性的格式写入文件&#xff0c;并且指定缩进为2个空格&#xff0c;你可以使用json模块来实现。json模块提供了一种很方便的方法来进行序列化和反序列化Python对象。下面是一个具体的示例&#xff1a; 字典变量以具有可…...

设计循环队列

文章目录 一、循环队列的构建二、判断是否为空三、判断队列是否满了四、队列插入五、队列的删除六、队列取头尾 设计循环队列 下面是队列提供的接口函数 typedef struct {int* a;int k;int front;int rear; } MyCircularQueue;MyCircularQueue* myCircularQueueCreate(int k) {…...

linux文件解压和压缩命令

linux文件解压和压缩命令 1.格式.zip 解压&#xff1a;unzip filename.zip 压缩&#xff1a;zip filename.zip directoryName 2.格式.rar 解压&#xff1a; #解压方式1&#xff08;会在当前解压目录内产生一个以压缩包名字命名的目录&#xff0c;目录内是解压内容&#xff09; …...

飞链云:让AI创造价值,让人类享受收益

我梦想有天&#xff0c;每个有能力的人都可以做自己喜欢的事情&#xff0c;都应该去做自己喜欢的事情&#xff0c;并且可以获得应有的收益。 有的人可以称之为“人”&#xff0c;有的人你得称他为鬼&#xff0c;有的人不如畜生。 如今社会&#xff0c;每个人都为了“生活”日…...

[NSSCTF 2nd]MyJs

做一题ejs原型链污染 首先是登录界面 源码里面提示了源码的路由 js不熟先审计一下 const express require(express); #导入Express框架&#xff0c;用于构建Web应用程序的服务器和路由 const bodyParser require(body-parser); #导入body-parser中间件&#xff0c;用于解析…...

NLP-词向量、Word2vec

Word2vec Skip-gram算法的核心部分 我们做什么来计算一个词在中心词的上下文中出现的概率&#xff1f; 似然函数 词已知&#xff0c;它的上下文单词的概率 相乘。 然后所有中心词的这个相乘数 再全部相乘&#xff0c;希望得到最大。 目标函数&#xff08;代价函数&#xff0…...

Java学习--学生管理系统(残破版)

代码 Main.java import java.util.ArrayList; import java.util.Scanner;public class Main {public static void main(String[] args) {ArrayList<Student> list new ArrayList<>();loop:while (true) {System.out.println("-----欢迎来到阿宝院校学生管理系…...

柯西矩阵介绍

经典定义 柯西矩阵&#xff08;Cauchy Matrix&#xff09;&#xff0c;是一种特殊类型的矩阵&#xff0c;它在数学中的多个领域&#xff0c;包括线性代数、数值分析和插值理论中都有重要应用。柯西矩阵以19世纪法国数学家奥古斯丁-路易柯西的名字命名。 柯西矩阵是一个方阵&am…...

PureFlash v1.9.1特性介绍

PureFlashv1.9.1版本特性主要有4个&#xff1a; 1. 支持RDMA网络 使用RDMA协议可以大大减少对CPU的消耗&#xff0c;性能提升30%以上。 PureFlash的网络配置分为存储节点间网络&#xff08;存储后端网&#xff09;和客户端网络&#xff08;前端网&#xff09;。都支持使用RD…...

阿里云ACP云计算备考笔记 (5)——弹性伸缩

目录 第一章 概述 第二章 弹性伸缩简介 1、弹性伸缩 2、垂直伸缩 3、优势 4、应用场景 ① 无规律的业务量波动 ② 有规律的业务量波动 ③ 无明显业务量波动 ④ 混合型业务 ⑤ 消息通知 ⑥ 生命周期挂钩 ⑦ 自定义方式 ⑧ 滚的升级 5、使用限制 第三章 主要定义 …...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院挂号小程序

一、开发准备 ​​环境搭建​​&#xff1a; 安装DevEco Studio 3.0或更高版本配置HarmonyOS SDK申请开发者账号 ​​项目创建​​&#xff1a; File > New > Create Project > Application (选择"Empty Ability") 二、核心功能实现 1. 医院科室展示 /…...

Module Federation 和 Native Federation 的比较

前言 Module Federation 是 Webpack 5 引入的微前端架构方案&#xff0c;允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...

【python异步多线程】异步多线程爬虫代码示例

claude生成的python多线程、异步代码示例&#xff0c;模拟20个网页的爬取&#xff0c;每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程&#xff1a;允许程序同时执行多个任务&#xff0c;提高IO密集型任务&#xff08;如网络请求&#xff09;的效率…...

全志A40i android7.1 调试信息打印串口由uart0改为uart3

一&#xff0c;概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本&#xff1a;2014.07&#xff1b; Kernel版本&#xff1a;Linux-3.10&#xff1b; 二&#xff0c;Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01)&#xff0c;并让boo…...

Map相关知识

数据结构 二叉树 二叉树&#xff0c;顾名思义&#xff0c;每个节点最多有两个“叉”&#xff0c;也就是两个子节点&#xff0c;分别是左子 节点和右子节点。不过&#xff0c;二叉树并不要求每个节点都有两个子节点&#xff0c;有的节点只 有左子节点&#xff0c;有的节点只有…...

学习STC51单片机32(芯片为STC89C52RCRC)OLED显示屏2

每日一言 今天的每一份坚持&#xff0c;都是在为未来积攒底气。 案例&#xff1a;OLED显示一个A 这边观察到一个点&#xff0c;怎么雪花了就是都是乱七八糟的占满了屏幕。。 解释 &#xff1a; 如果代码里信号切换太快&#xff08;比如 SDA 刚变&#xff0c;SCL 立刻变&#…...

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来&#xff0c;在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂&#xff0c;网络攻击、数据泄露等事件频发&#xff0c;现行法律已难以完全适应新的风险挑战。 2025年3月28日&#xff0c;国家网信办会同相关部门起草了《网络安全…...

书籍“之“字形打印矩阵(8)0609

题目 给定一个矩阵matrix&#xff0c;按照"之"字形的方式打印这个矩阵&#xff0c;例如&#xff1a; 1 2 3 4 5 6 7 8 9 10 11 12 ”之“字形打印的结果为&#xff1a;1&#xff0c;…...