数据结构day5

一、思维导图

二、课后练习


1、使用循环链表完成约瑟夫环问题

2、使用栈,完成进制转换(输入:一个整数,进制数,输出:该数的对应的进制数)

//头文件

#ifndef DEC_TO_BIN_H
#define DEC_TO_BIN_H

#include <myhead.h>

typedef int datatype;
#define MAX 100

typedef struct
{
	datatype *data;
	int top;
}Stack,*StackPtr;

//创建栈
StackPtr stack_create();

//判空
int stack_empty(StackPtr S);

//判满
int stack_full(StackPtr S);

//入栈
void stack_push(StackPtr S,datatype element);

//出栈
void stack_pop(StackPtr S);

//遍历栈
void stack_show(StackPtr S);

//将整数转换成对应的进制数
void Dec_to_Bin(StackPtr S, int element,int num);



#endif

//功能函数

#include "Dec_to_Bin.h"

//创建栈
StackPtr stack_create()
{
	//在堆区申请一个栈大小的空间
	StackPtr S = (StackPtr)malloc(sizeof(Stack));
	if(NULL == S)
	{
		printf("创建失败\n");
		return NULL;
	}

	//栈申请成功,申请存储栈的空间
	//申请MAX个datatype类型数据大小的空间
	S->data = (datatype *)malloc(sizeof(datatype) * MAX);
	if(NULL == S->data)
	{
		printf("申请栈存储空间失败\n");
		return NULL;
	}

	//给空间内容初始化
	memset(S->data,0,sizeof(datatype)*MAX);

	//栈顶元素变量初始化
	S->top = -1;
	//返回栈地址
	return S;
}

//判空
int stack_empty(StackPtr S)
{
	return S->top == -1;
}
//判满
int stack_full(StackPtr S)
{
	return S->top == MAX-1;

}
//入栈
void stack_push(StackPtr S,datatype element)
{
	//判断逻辑
	if(NULL == S || stack_full(S))
	{
		printf("入栈失败\n");
		return;
	}

	//入栈
	//先偏移栈顶位置
	S->top++;
	//再将数据压入栈中
	S->data[S->top] = element;
}
//出栈
void stack_pop(StackPtr S)
{
	//判断逻辑
	if(NULL == S || stack_empty(S))
	{
		printf("出栈失败\n");
		return;
	}

	//出栈
	//先弹后减
	printf("%d出栈成功\n",S->data[S->top]);
	S->top--;
}

//遍历栈
void stack_show(StackPtr S)
{
	//判断逻辑
	if(NULL == S ||stack_empty(S))
	{
		printf("遍历失败\n");
		return;
	}

	for(int i=S->top;i>=0;i--)
	{
		printf("%d",S->data[i]);
	}
	printf("\n");
}


//将整数转换成对应的进制数
void Dec_to_Bin(StackPtr S, int element,int num)
{
	//对element循环取余并压入栈中
	while(element)
	{
		stack_push(S,element%num);
		//将element除以num
		element /= num;
	}
}

//主函数

#include "Dec_to_Bin.h"
int main(int argc, const char *argv[])
{
	while(1)
	{
		//创建栈
		StackPtr S = stack_create();

		//提示输入
		int element,num;
		printf("请输入一个整数和你需要转换的进制数:");
		scanf("%d%d",&element,&num);

		//将整数转换成进制数存入栈中
		Dec_to_Bin(S,element,num);

		//将栈输出
		printf("该整数的%d进制数为:",num);
		stack_show(S);
	}
 
	return 0;
}

相关推荐

  1. 数据结构day2

    2024-07-23 08:20:01       46 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-23 08:20:01       95 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-23 08:20:01       103 阅读
  3. 在Django里面运行非项目文件

    2024-07-23 08:20:01       84 阅读
  4. Python语言-面向对象

    2024-07-23 08:20:01       93 阅读

热门阅读

  1. Mybatis-plus常用注解

    2024-07-23 08:20:01       26 阅读
  2. 华为OD机试 - 文件缓存系统——优先队列解法

    2024-07-23 08:20:01       27 阅读
  3. 计算机网络之数据链路层

    2024-07-23 08:20:01       24 阅读
  4. 今天是闭包,装饰器和案例

    2024-07-23 08:20:01       25 阅读
  5. 【Golang 面试基础题】每日 5 题(三)

    2024-07-23 08:20:01       25 阅读
  6. 【策略模式在项目中的实际应用】

    2024-07-23 08:20:01       24 阅读
  7. 前端设计模式面试题汇总

    2024-07-23 08:20:01       21 阅读
  8. 预训练语言模型实践笔记

    2024-07-23 08:20:01       29 阅读
  9. 坑人的macos tar 命令 (实际上是bsdtar)换用 gnu tar

    2024-07-23 08:20:01       26 阅读
  10. windows下玩转DockerDesktop--学习笔记

    2024-07-23 08:20:01       24 阅读
  11. 45、PHP 实现滑动窗口的最大值

    2024-07-23 08:20:01       23 阅读
  12. PHP框架简介

    2024-07-23 08:20:01       20 阅读
  13. Scratch语言详解

    2024-07-23 08:20:01       21 阅读