数据结构实验--实验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

相关文章

使用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

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

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

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

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

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

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

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N