数制转换_顺序栈_头文件

2024-02-06 00:32
文章标签 转换 顺序 头文件 数制

本文主要是介绍数制转换_顺序栈_头文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

将写好的头文件添加到工程的文件夹Head内,然后再编写源程序。

//
//Description:顺序栈.h
//
#include <iostream>
#include <malloc.h>
using namespace std;#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10typedef int Status;
typedef int SElemType;//顺序栈的定义
typedef struct
{SElemType *base;SElemType *top;int stacksize;
}SqStack;//---------------以下为基本操作
//构造一个栈
Status InitStack(SqStack &S)
{S.base = (SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType));if (!S.base){cout << "存储空间分配失败!" << endl;return 0;}S.top = S.base;S.stacksize = STACK_INIT_SIZE;return 1;
}//初始化一个栈
Status Input(SqStack &S, int n)
{int i;if (n > 0){cout << "请输入第" << 1 << "个元素的值" << endl;cin >> *S.base;S.top++;for (i = 2; i <= n; i++){cout << "请输入第" << i << "个元素的值" << endl;cin >> *S.top;S.top++;}return 1;}else{cout << "输入数据不合法!" << endl;return 0;}}
//判断栈是否为空栈
Status StackEmpty_Or_not(SqStack S)
{if (S.top == S.base){return 0;}elsereturn 1;}//查看栈顶元素
Status GetTop(SqStack S, SElemType &e)
{if (S.top == S.base){cout << "目前为空栈,无栈顶元素!" << endl;return 0;}e = *(S.top - 1);cout << "当前栈顶元素为" << e << endl;return 1;
}//向栈顶插入一个元素
Status Push(SqStack &S, SElemType e)
{if (S.top - S.base >= S.stacksize){S.base = (SElemType *)realloc(S.base, (S.stacksize + STACKINCREMENT)*sizeof(SElemType));if (!S.base){cout << "执行插入操作分配存储空间时失败!" << endl;return 0;}S.top = S.base + S.stacksize;S.stacksize += STACKINCREMENT;}*S.top++ = e;return 1;
}//删除栈顶元素
Status Pop(SqStack &S, SElemType &e)
{if (S.top == S.base){cout << "目前为空栈,无法执行删除栈顶元素的操作!" << endl;return 0;}e = *--S.top;return 1;
}

//
//Description:顺序栈.cpp
//
#include <iostream>
#include "顺序栈.h"
using namespace std;SqStack stc;//对于输入的数据进行数制转换
int conversion()
{InitStack(stc);int value, jinzhi;
loop:  cout << "请输入欲进行转换的数据以及欲转换成的进制数(*两者都得大于0)" << endl;cin >> value >> jinzhi;if (value <= 0 || jinzhi <= 0){cout << "您输入的数据不合法(应该>0)" << endl;goto loop;//  return 0;}cout << "数据 " << value << " 转换成 " << jinzhi << " 进制的数据后,其值为 :" << endl;while (value){Push(stc, value%jinzhi);value = value / jinzhi;}while (StackEmpty_Or_not(stc)){Pop(stc, value);cout << value;}cout << endl;return 1;
}void main()
{cout << "================数制转换===========" << endl;conversion();
}

这篇关于数制转换_顺序栈_头文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方