顺序栈的进制转换
//顺序栈
#include<stdio.h>
#include<malloc.h>
#define MAXSIZE 100
struct stack { //建立结构体
int elem[MAXSIZE];
int top;
};
//struct stack *s; //建立一个包含两个元素的栈
void in_stack(struct stack *s,int x) //入栈
{
while(x!=0)
{
s->elem[s->top+1]=x%2; //栈的元素从0开始存 ++s.top余数放入elem数组中
s->top++; //指向下一个
x=x/2; //改变x的值
}
}
int out_stack(struct stack *s) //出栈
{
int x;
while(s->top!=-1) //当s->top等于-1时结束循环 ,栈空
{
//printf("%d",s->elem[s->top]);
x=s->elem[s->top];
s->top--;
printf_stack(x); //不需要加return ,调用printf_stack输出
}
}
void input_stack(int *x) //输入一个十进制数
{
printf("\n->请输入一个十进制数:");
scanf("%d",x);
printf("\n->输入的十进制数对应的二进制数:");
}
int printf_stack(int x) //输出转换的二进制数
{
printf("%d",x);
}
void main()
{
int x;
struct stack *s; //建立一个包含两个元素的链式表 *s代表指针需要开辟空间
s=(struct stack *)malloc(sizeof(struct stack)); //开辟存储空间
s->top=-1; //初始化
input_stack(&x);
in_stack(s,x);
out_stack(s);
//printf_stack(k);
}
本文来自博客园,作者:JackieDYH,转载请注明原文链接:https://www.cnblogs.com/JackieDYH/p/17634991.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现