顺序栈之共享栈实现——C语言

参考书:数据结构教程 第5版 李葆春 P83共享栈

#include <stdio.h>
#include <string.h>
#include <stdlib.h>#define MaxSize 10/*共享栈*/
typedef struct 
{char data[MaxSize];int top1,top2,len;
}DStack;/*初始化*/
void InitStack(DStack *s){s->top1=-1,s->top2=MaxSize,s->len=MaxSize;s=(DStack *)malloc(sizeof(DStack));printf("%s\n",s->data);
}/*销栈*/
void DestroyStack(DStack *s){free(s);
}/*判断栈是否为空*/
int StackEmpty(DStack *s, int i){/*对栈1操作*/if (i==1){return (s->top1==-1);}if (i==2){return (s->top2==MaxSize);}}/*进栈*/
void Push(DStack *s, int e, int i){if (i==1&&s->len>0){s->top1++;s->data[s->top1]=e;s->len--;}if (i==2&&s->len>0){s->top2--;s->data[s->top2]=e;s->len--;}
}/*出栈*/
void Pop(DStack *s, int *e, int i){if (i==1){*e=s->data[s->top1];s->top1--;}if (i==2){*e=s->data[s->top2];s->top2++;}
}/*取栈顶元素*/
void GetTop(DStack *s,int *e, int i){if (i==1){*e=s->data[s->top1];}if (i==2){*e=s->data[s->top2];}
}/*实例:输入两个字符串*/
void Input(char str1[], char str2[]){char e;DStack st;InitStack(&st);/*进栈*/for (int j = 0; str1[j]!='\0'; j++){Push(&st, str1[j], 1);}for (int k = 0; str2[k]!='\0'; k++){Push(&st, str2[k], 2);}/*判断栈空*/if(StackEmpty(&st,1)){printf("栈1空\n");}if (StackEmpty(&st,2)){printf("栈2空\n");}/*取栈顶*/GetTop(&st,&e,1);printf("栈1顶:%c\n",e);GetTop(&st,&e,2);printf("栈2顶:%c\n",e);/*出栈*/while (st.top1){Pop(&st,&e,1);printf("%c",e);}printf("\n");while (st.top2<MaxSize){Pop(&st,&e,2);printf("%c",e);}printf("\n");/*销栈*/DestroyStack(&st);// printf("%d\n",st.top1);// printf("%d\n",st.top2);// printf("%s",st.data);    
}int main(){char str1[10]={"qwertyu"};char str2[10]={"zxcvb"};Input(str1, str2);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/609065.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Huggingface】如何访问Huggingface,Huggingface镜像

镜像站&#xff1a; https://hf-mirror.com/本站域名 hf-mirror.com&#xff0c;用于镜像 huggingface.co 域名。 更多用法&#xff08;多线程加速等&#xff09;详见这篇文章。简介&#xff1a; 方法一&#xff1a;使用huggingface 官方提供的 huggingface-cli 命令行工具。…

解决不同请求需要的同一实体类参数不同(分组校验validation)

问题概述 新增目录是自动生成id&#xff0c;不需要id参数&#xff1b;更新目录需要id&#xff0c;不能为空 pom.xml中已有spring-boot-starter-validation依赖 <!--validation(完成属性限制&#xff0c;参数校验)--><dependency><groupId>org.springframew…

“揭秘性能测试工具:优化软件性能的关键秘籍“

性能测试工具的设计宗旨是为了模拟用户对软件应用程序或系统的各种操作&#xff0c;旨在评估关键的性能指标&#xff0c;包括响应时间、吞吐量、并发能力和资源利用率。 通过这些工具模拟的多用户环境&#xff0c;我们能够产生与实际工作负载相似的条件&#xff0c;并监测系统…

业界首款PCIe 4.0/5.0多通道融合接口SSD技术解读

之前小编写过一篇文章劝大家不要碰PCIe 5.0 SSD&#xff0c;详细内容&#xff0c;可以再回顾下&#xff1a; 扩展阅读&#xff1a;当下最好不要入坑PCIe 5.0 SSD 如果想要进一步了解PCIe 6.0&#xff0c;欢迎点击阅读&#xff1a; 浅析PCIe 6.0功能更新与实现的挑战 PCIe 6.…

pyqt调用UI和开启子进程

UI制作 qrc 注意调用UI前把样式表里绑定的资源(qrc)转换成py导入进去 xxx.qrc转xxx.py 两种方法 1命令 pyrcc5 -o icons_rc.py icons.qrc 2外部工具pyrcc 实参 -o $FileNameWithoutExtension$.py $FileNameWithoutExtension$.qrcsdz.qrc→→sdaz.py 在代码里写 import…

Influxdb2修改管理员密码

通过恢复管理员令牌来重置InfluxDB2管理员的密码 1.找到数据库的配置文件 一般为config.json 2.配置文件的的blod文件配置 3.在这个混合文本和二进制json文件中搜索已知的用户名或token之类的字符串。 例如&#xff1a; "id":"0bd73badf2941000","…

AI-数学-高中-3.二次函数的根的分布问题的解题方法

原作者学习视频&#xff1a;二次】3二次函数根分布问题&#xff08;中档&#xff09;_哔哩哔哩_bilibili 一、伟达定理&#xff08;根与0比较的二次函数&#xff09; 示例&#xff1a; 二、画图法&#xff1a; 1.开口方向的确定&#xff0c;有的示例可能存在向上、下两种情况…

Qt/QML编程学习之心得:Linux下读写GPIO(23)

在linux嵌入式系统中,经常需要一些底层操作,Linux就如window一样,也对底层BSP进行了封装,对device driver进行了封装,使用的话基本就是文件读写的方式来读取,所以也大大简化了上层应用对底层硬件的访问难度。 比如要对GPIO口进行访问,在Qt中有几种方法: 使用命令行方…

Centos7 手动更改系统时间

文章目录 1.更改系统时间2.写入系统时间3.查看是否写入成功 1.更改系统时间 date -s "2017-12-18 09:40:00"2.写入系统时间 hwclock -w3.查看是否写入成功 timedatectl

初识硬件之三极管

1 什么是三极管 概述 三极管全称是“晶体三极管”&#xff0c;也被称作“晶体管”&#xff0c;是一种具有放大功能的半导体器件。通常指本征半导体三极管&#xff0c;即BJT管。 三极管封装 有插件和贴片之分 如下图左一和左二就是插件形式&#xff0c;上面的金属片和洞孔是…

服务器中了DevicData勒索病毒怎么处理

DevicData勒索病毒是最近一段时间非常流行的勒索病毒类型&#xff0c;有很多企业都不幸中招&#xff0c;给生产和经营带来了很大的影响。所以云天数据恢复中心决定就这种类型的勒索病毒&#xff0c;来和各位讲讲当服务器中了DevicData勒索病毒怎么处理。 特征 1&#xff0c;文件…

位运算相关

简单&#xff1a; 191. 位1的个数-CSDN博客 67. 二进制求和-CSDN博客 190. 颠倒二进制位-CSDN博客 136. 只出现一次的数字-CSDN博客 中等&#xff1a;

【C语言题解】 | 101. 对称二叉树

101. 对称二叉树 101. 对称二叉树代码 101. 对称二叉树 这个题目要求判断该二叉树是否为对称二叉树&#xff0c;此题与上一题&#xff0c;即 100. 相同的树 这个题有异曲同工之妙&#xff0c;故此题可借鉴上题。 我们先传入需要判断二叉树的根节点&#xff0c;通过isSameTree()…

vue 工作记录登录后的一些好方法

//记住要跳转的地址 function handleLogin() { loginFormRef.value.validate((valid: boolean) > { if (valid) { loading.value true; userStore .login(loginData.value) .then(() > { const query: LocationQuery route.query; const redirect (query.redirect as…

logrus 打印日志时间注意事项

问题描述 程序运行中打印时间 和 logrus打印日志时间 差距十几分钟 go 日志打印处 log_init.LogIcmp.Info("Current time") 日志打印结果 {"func":"main.main","level":"info","msg":"Current time",…

EI级 | Matlab实现VMD-TCN-GRU变分模态分解结合时间卷积门控循环单元多变量光伏功率时间序列预测

EI级 | Matlab实现VMD-TCN-GRU变分模态分解结合时间卷积门控循环单元多变量光伏功率时间序列预测 目录 EI级 | Matlab实现VMD-TCN-GRU变分模态分解结合时间卷积门控循环单元多变量光伏功率时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.【EI级】Matlab实现…

C# 强制类型转换和as区别和不同使用场景

文章目录 1.强制类型转换2. as 运算符3.实例总结&#xff1a; 在C#中&#xff0c;as 和 强制类型转换&#xff08;例如 (T)value&#xff09;的主要区别在于它们处理类型转换不成功时的行为和适用场景&#xff1a; 1.强制类型转换 使用语法&#xff1a;Type variable (Type)…

Python基础知识:整理7 字典的定义及其相关操作

1 字典的定义 # 1. 字典的定义 # 定义字典的字面量 # {key: value, key: value, ......, key: value}# 定义字典变量 # my_dict {key: value, key: value, ......, key: value}# 定义空字典 # my_dict {} # my_dict dict()定义重复Key的字典 my_dict1 {"张三": …

基于JavaWeb+SSM+Vue四六级词汇微信小程序系统的设计和实现

基于JavaWebSSMVue四六级词汇微信小程序系统的设计和实现 源码获取入口KaiTi 报告Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 KaiTi 报告 &#xff08;1&#xff09;课题背景 伴随着社会的快速发展, 现代社…

sql查看指定时间段的数据

要查看指定时间段的数据&#xff0c;您可以使用SQL中的WHERE子句来过滤日期或时间列&#xff0c;以仅选择在指定时间段内的行。以下是一个示例查询&#xff0c;假设您有一个名为table_name的表&#xff0c;其中包含一个名为date_column的日期列&#xff1a; SELECT * FROM tab…