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

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中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

Python实现视频转换为音频的方法详解

《Python实现视频转换为音频的方法详解》这篇文章主要为大家详细Python如何将视频转换为音频并将音频文件保存到特定文件夹下,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5. 注意事项

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2