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

相关文章

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

使用Python实现网页表格转换为markdown

《使用Python实现网页表格转换为markdown》在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,本文将使用Python编写一个网页表格转Markdown工具,需... 在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,以便在文档、邮件或