IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 栈的顺序表和链表实现代码 -> 正文阅读

[数据结构与算法]栈的顺序表和链表实现代码

第三章代码

不知不觉已经第三章了。坚持更新,虽然可能看到的人比较少。人气也不高。但是知道自己懂了进步了就可以了。
栈(用顺序表实现栈)

#include<stdio.h>
#define Maxsize 10
//定义栈结构
typedef struct{
	int data[Maxsize];//数组
	int top;//逻辑上充当栈指针
}SqStack;
//初始化栈 
void Initstack(SqStack &S){
	S.top=-1;
}
//判空 
bool Emptystack(SqStack S){
	if(S.top==-1) return true;
	else return false;
}
//入栈,把元素压入栈顶; 
bool Push(SqStack &S,int e){
	if(S.top==Maxsize) return false;
	S.top=S.top+1;
	S.data[S.top]=e;
	return true;
}
//出栈,把栈顶元素弹出 
bool Pop(SqStack &S,int &e){
	if(S.top==-1) return false;
	e=S.data[S.top];
	S.top=S.top-1;
	return true;
}
//获取栈顶数据;
bool GetTopelem(SqStack S,int &e){
	if(S.top==-1) return false;
	e=S.data[S.top];
	return true;
} 

int main(){
	SqStack S;
	return 0; 
} 

这一块代码有点简单了。没什么好注释的了。听王道的课自己敲一遍就很简单。
单链表实现栈
注意点挺多的还;基本逻辑应该没啥问题的,听过课就能懂!!!
自己动动手哈!!!

#include<stdio.h>
#include<stdlib.h> 
#include<malloc.h>
typedef struct Linknode{
	int data;
	struct Linknode * next;
}Linknode,*Listack;
//初始化栈
bool InitListack(Listack &S){
	S = (Linknode *) malloc(sizeof(Linknode));//申请内存
    if(S->next==NULL) return false;//申请失败
    S->data = 0;//初始化链栈头结点数据域
    S->next = NULL;//初始化链栈头结点指针域
    return true;

}
//入栈 
bool Push(Listack &S,int e){
	Linknode *headpoint;//指向新节点的指针 
	headpoint=(Listack)malloc(sizeof(Linknode));//分配空间 
	if(headpoint==NULL) return false;//申请空间失败
	if(S->next==NULL){
		headpoint->data=e;//给节点赋值 
		headpoint->next=NULL;//链接新节点 
		S->next=headpoint;
		return true;
	}else{
		headpoint->data=e;//给节点赋值 
		headpoint->next=S->next;//链接新节点 
		S->next=headpoint;
		return true;
	}
}
//出栈
bool Pop(Listack &S,int &e){
	Linknode *headpoint=S->next;//指向出栈节点的指针
	if(S->next==NULL) return false;//空栈,没有节点可以出栈了 
	else{
		//头结点链接第二个元素节点 
		e=headpoint->data;
		S->next=headpoint->next;
		free(headpoint);
		return true; 
	}
} 
bool Emptystack(Listack S){
	if(S->next==NULL) return true;
	else return false;
}
 
int main(){
	Listack S;
	InitListack(S);
	int x,e;
	printf("请输入一个值0退出;1表示出栈;2表示入栈:\n"); 
	scanf("%d",&x);
	while(x!=0){
		if(x==1){
			printf("新节点值输入:\n");
			scanf("%d",&e);
			Push(S,e);
		}
		if(x==2){
			if(!Emptystack(S)){
				Pop(S,e);
				printf("出栈节点值:%d\n",e);
			}
			else printf("出栈失败!!"); 
		}
		printf("请输入一个值0退出;1表示出栈;2表示入栈:\n"); 
		scanf("%d",&x);
	}
	return 0;
}

运行演示
在这里插入图片描述
代码写半小时调优1小时,心酸!!!!且行且珍惜!

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-29 12:21:18  更:2022-04-29 12:23:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年9日历 -2024/9/20 0:11:44-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码