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

进制转换:

回文串判断

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/587520.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

在安装有Acer软件保护卡的电脑上安装PRCS6

PRCS6下载地址https://www.yuque.com/u33774918/pqzsy8/gdo8n6hibxgzsghw 第一步&#xff0c;电脑开机进入windows系统 第二步&#xff0c;解压PRCS6到电脑桌面 第三步&#xff0c;打开电脑桌面的PRCS6文件夹&#xff0c;双击‘点我安装’&#xff0c;开始安装 第四步&…

windows浅尝NW.js

windows浅尝NW.js 在本指南中&#xff0c;我们将详细介绍如何在windows上部署NW.js,实现应用的构成、启动方式、开发环境 环境部署 首先我们需要从官网下载对应的压缩包 (https://nwjs.io/downloads/) 下载完成后解压&#xff0c;可以看到对应的文件目录 然后我们运行目录下…

数据结构与算法实验题五道 A一元多项式的求导 B还原二叉树 C 六度空间 D 基于词频的文件相似度 E 模拟excel排序

A (1) 输入格式说明&#xff1a; 以指数递降方式输入多项式非零项系数和指数&#xff08;绝对值均为不超过1000的整数&#xff09;。数字间以空格分隔。 (2) 输出格式说明&#xff1a; 以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔&#xff0c;但…

ffmpeg中stream_loop参数不生效原因分析

问题 使用ffmpeg把一个视频文件发布成一个rtmp流&#xff0c;并设置成循环推流&#xff0c;此时需要使用参数stream_loop&#xff0c;命令如下: ffmpeg.exe -stream_loop -1 -re -i D:\tools\ffmpeg-5.1.2\bin\sei.h264 -c copy -f flv -safe 0 rtmp://localhost:1935/live/te…

【智能算法】鹦鹉优化算法(WO)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2024年&#xff0c;J Lian等人受到鹦鹉学习行为启发&#xff0c;提出了鹦鹉优化算法&#xff08;Parrot Optimizer, PO&#xff09;。 2.算法原理 2.1算法思想 PO灵感来自于在驯养的鹦鹉中观察到的…

go稀疏数组

稀疏数组 稀疏数组 稀疏数组 package testimport ("encoding/json""fmt""io/ioutil""log""reflect""testing" )type ValNode struct {Row int json:"row"Col int json:"col"Val int json:&qu…

分布式与一致性协议之Raft算法与一致哈希算法(一)

Raft算法 Raft与一致性 有很多人把Raft算法当成一致性算法&#xff0c;其实它不是一致性算法而是共识算法&#xff0c;是一个Multi-Paxos算法&#xff0c;实现的是如何就一系列值达成共识。并且&#xff0c;Raft算法能容忍少数节点的故障。虽然Raft算法能实现强一致性&#x…

黑马 - websocket搭建在线聊天室

这里写自定义目录标题 一、消息推送常见方式二、websocket 是什么&#xff1f;三、websocket api的介绍1、客户端 &#xff08;浏览器&#xff09; 四、实现在线聊天室1、需求2、聊天室流程分析3、消息格式4、代码实现 一、消息推送常见方式 1、轮训方式 2、SSE&#xff08;…

通用漏洞评估系统CVSS4.0简介

文章目录 什么是CVSS&#xff1f;CVSS 漏洞等级分类历史版本的 CVSS 存在哪些问题&#xff1f;CVSS 4.0改进的“命名法”改进的“基本指标”考虑“OT/IOT”新增的“其他指标”CVSS 4.0存在的问题 Reference: 什么是CVSS&#xff1f; 在信息安全评估领域&#xff0c;CVSS为我们…

IP-guard WebServer 2024年两个漏洞简单分析

前言 这个漏洞看完索然无味&#xff0c;但是手上又刚好有源码&#xff0c;不看他一下又觉得可惜 权限绕过漏洞(QVD-2024-14103)简单分析 网上冲浪的时候&#xff0c;看到个买不起的CSDN专栏 这里基本上定位到是_mApplyList 出了问题&#xff0c;前面两个是ipguard webserve…

MATLAB 函数

MATLAB 函数 函数是一起执行任务的一组语句。在MATLAB中&#xff0c;函数是在单独的文件中定义的。文件名和函数名应该相同。 函数在其自己的工作空间&#xff08;也称为本地工作空间&#xff09;中对变量进行操作&#xff0c;与在MATLAB命令提示符下访问的工作空间&#xff0…

口袋实验室--使用AD2学习频谱参数测试

目录 1. 简介 2. 频谱相关参数 2.1 频谱相关基本概念 2.1.1 采样时间间隔 2.1.2 采样频率 2.1.3 采样点数 2.1.4 采样时间长度 2.1.5 谱线数 2.1.6 奈奎斯特频率 2.1.7 频谱分辨率 2.1.8 最高分析频率 2.1.9 频谱泄露 2.2 窗函数 2.2.1 AD2的窗函数 2.2.2 测试矩…

[NeurIPS-23] GOHA: Generalizable One-shot 3D Neural Head Avatar

[pdf | proj | code] 本文提出一种基于单图的可驱动虚拟人像重建框架。基于3DMM给粗重建、驱动结果&#xff0c;基于神经辐射场给细粒度平滑结果。 方法 给定源图片I_s和目标图片I_t&#xff0c;希望生成图片I_o具有源图片ID和目标图片表情位姿。本文提出三个分支&#xff1a;…

Ubuntu卸载已安装软件

前言 在Linux系统上安装了一些软件&#xff0c;但是卸载起来相比于Windows系统麻烦的多&#xff0c;这里总结了两种办法&#xff0c;希望对遇到这种问题的小伙伴能够有所帮助 1.Ubuntu Software 卸载 1.点击桌面上的Ubuntu Software并且选择installed 选中想要卸载的软件再按…

ECHARTS学习

坐标轴 option {xAxis: {type: category,data: [A, B, C]},yAxis: {type: value},series: [{data: [120, 200, 150],type: line}] }; 1、坐标轴的默认类型type是数值型&#xff0c;而xAxis指定了类目型的data&#xff0c;所以Echarts也能识别出这是类目型的坐标轴&#xff0c;…

C# 实现格式化文本导入到Excel

目录 需求 Excel 的文本文件导入功能 范例运行环境 配置Office DCOM 实现 组件库引入 OpenTextToExcelFile 代码 调用 小结 需求 在一些导入功能里&#xff0c;甲方经常会给我们一些格式化的文本&#xff0c;类似 CSV 那样的纯文本。比如有关质量监督的标准文件&…

C++入门——基本概念与关键字(上)

兜兜转转终于来到C的学习&#xff0c;C作为一种更高级的语言&#xff0c;是在C的基础之上&#xff0c;容纳进去了面向对象编程思想&#xff0c;并增加了许多有用的库&#xff0c;以及编程范式&#xff0c;本节笔者旨在带领读者理解C是如何对C语言设计不合理的地方进行优化的&am…

【二叉树——数据结构】

文章目录 1.二叉树1.基本概念.几种特殊的二叉树 2.考点3.二叉树的存储结构4.二叉树的遍历5.线索二叉树 1.二叉树 1.基本概念. 二叉树是n(n>0)个结点的有限集合 或者为空二叉树&#xff0c;即n0 或者由一个根结点和两个互不相交的被称作根的左子树和右子树组成。 每个结点至…

Linux系统编程——操作系统的初步认识(Operator System)

目录 一&#xff0c;关于操作系统 二&#xff0c;计算机的层次设计 2.1 硬件层 2.2 驱动层 2.3 操作系统层 2.4 用户层 2.5 系统调用接口 2.6 用户调用接口 三&#xff0c;操作系统管理的精髓 —— 先描述&#xff0c;再组织 3.1 什么是先描述&#xff1f; 3.2 什么…

php反序列化以及相关例题

目录 一、什么是序列化和反序列化&#xff1f; 二、相关函数 serialize()函数&#xff1a; unserialize()函数&#xff1a;反序列化 三、PHP序列化格式 四、序列化与反序列化的作用 五、各种数据类型序列化后的效果 六、魔术方法 七、反序列化的一些绕过 八…