数据结构实验--实验02 栈的应用(数制转换及回文判断)

2024-05-01 20:12

本文主要是介绍数据结构实验--实验02 栈的应用(数制转换及回文判断),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、实验内容

二、算法实现

1、用栈的特性实现进转换的思路:参考手算求进制转换的思路——除r取余法,这里的r表示基数,8进制的基数就是8,那么将十进制数转换成8进制数手算的方法就是除8取余法,具体手算方法如图:

从以上手算模拟过程我们得到启发,将每次所得余数进栈,最后再全部出栈所得到的输出序列就是进制转换的结果

2、用栈的特性判断一个字符串是否是回文串,我们可以扫描该字符串,并将字符串中的字符依次入栈,那么栈中数据域存放的就是该字符串的逆转字符串,此时只需使用简单的字符串比较函数strcmp判断当前字符串与栈中的字符串是否相等就可以判断该字符串是否是回文串了

1、栈的定义

//顺序栈的定义和实现
typedef struct SqStack {ElemType data[MAXSIZE];ElemType top;           //栈顶指针
}SqStack;

 2、栈的初始化操作实现

//初始化栈
void InitStack(SqStack& s)
{s.top = -1;         //当栈顶指针为-1时表示栈空
}

3、栈的判满和判空操作


//栈的判空操作
bool StackEmpty(SqStack s)
{return s.top == -1;
}//栈的判满操作
bool StackOverFlow(SqStack s)
{return s.top == MAXSIZE - 1;
}

4、入栈操作

//进栈操作
bool Push(SqStack& s, ElemType e)
{//入栈判满if (StackOverFlow(s)) { return false; }s.data[++s.top] = e;return true;
}

5、出栈操作


//出栈操作
bool Pop(SqStack& s, ElemType& e)
{//出栈判空if (StackEmpty(s)) { return false; }e = s.data[s.top--];return true;
}

6、进制转换算法实现

//用栈实现进制转换
void Convert(SqStack &s, int x)
{int base,temp;printf("转换成几进制:?\n");scanf("%d", &base);//进制转换while (x != 0){temp = x % base;Push(s, temp);x = x / base;}
}

5、回文串判断算法实现


//利用栈的特性判断一个字符串是否是回文串
void isEqualReverse(SqStack &s, char* str)
{int i;for (i = 0; str[i] != '\0'; i++){Push(s, str[i]);}Push(s, str[i]);if (strcmp(s.data, str) == 0){printf("Right!\n");}else{printf("Wrong!\n");}
}

6、完整源代码

//栈的定义和实现#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>#define ElemType int//定义顺序栈的最大容量
#define MAXSIZE 100//顺序栈的定义和实现
typedef struct SqStack {ElemType data[MAXSIZE];ElemType top;           //栈顶指针
}SqStack;//初始化栈
void InitStack(SqStack& s)
{s.top = -1;         //当栈顶指针为-1时表示栈空
}//栈的判空操作
bool StackEmpty(SqStack s)
{return s.top == -1;
}//栈的判满操作
bool StackOverFlow(SqStack s)
{return s.top == MAXSIZE - 1;
}//进栈操作
bool Push(SqStack& s, ElemType e)
{//入栈判满if (StackOverFlow(s)) { return false; }s.data[++s.top] = e;return true;
}//出栈操作
bool Pop(SqStack& s, ElemType& e)
{//出栈判空if (StackEmpty(s)) { return false; }e = s.data[s.top--];return true;
}//用栈实现进制转换
void Convert(SqStack &s, int x)
{int base,temp;printf("转换成几进制:?\n");scanf("%d", &base);//进制转换while (x != 0){temp = x % base;Push(s, temp);x = x / base;}
}
//
利用栈的特性判断一个字符串是否是回文串
//void isEqualReverse(SqStack &s, char* str)
//{
//	int i;
//	for (i = 0; str[i] != '\0'; i++)
//	{
//		Push(s, str[i]);
//	}
//	Push(s, str[i]);
//
//	if (strcmp(s.data, str) == 0)
//	{
//		printf("Right!\n");
//	}
//	else
//	{
//		printf("Wrong!\n");
//	}
//}int main()
{SqStack s;//初始化栈InitStack(s);int x, e;   //x表示要进行进制转换的数,t用于获取栈顶元素printf("请输入你需要进行转换的数字:\n");scanf("%d", &x);Convert(s, x);//输出转换后的结果printf("转换结果:\n");while (s.top != -1){Pop(s, e);printf("%d", e);}判断一个字符串是否是回文串//char str[MAXSIZE];//printf("请输入你所需要进行判断的字符串:\n");//scanf("%s", str);//isEqualReverse(s, str);return 0;}

7、实验结果

进制转换:

回文串判断

这篇关于数据结构实验--实验02 栈的应用(数制转换及回文判断)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

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

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

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

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

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

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11