进制转换器(C语言)

目录

1问题: 输入任意进制的数值,可以转换成任意进制的数值(2到36进制);

2思路:

3代码:(需要运用到数据结构栈的知识)

4运行结果:


1问题: 输入任意进制的数值,可以转换成任意进制的数值(2到36进制);

2思路:

因为十进制是中间值,就是任何进制转换成十进制只需要每位乘上自己进制的加权数即可,十进制转换成任意进制可以的逆余数即可

一、十进制转任意进制:
       十进制转任意进制时,将这个十进制数除以进制数,比如2(也就是十进制转二进制),得到商和一个从0~1的余数,然后再以这个商为被除数,除了进制数2,继续得到商和一个从0~1的余数。以此方式不断相除,直到得到的商为0为止。此时,得到若干个余数,把这些余数按从后到先的顺序排列起来,那么这个排列起来的值即为该十进制转换成二进制的值。计算如图所示:

最后得到的余数为二进制的非零的最高位,最先得到的余数为二进制的最低位,可知:十进制数9转换成二进制数为1001。

二、任意进制转十进制:
        任意进制转十进制时,以二进制数1001为例:该进制的最低位(右一)的值1就表示实际的十进制值1,次低位(右二)的值0表示进制数2的一次方的0倍即为0,次次低位(右三)的值0表示进制数2的二次方4的0倍即为0,最高位(左一)的值1表示进制数2的三次方8的1倍即为8,以此类推,将每位得到的十进制数相加得到9,该和即为二进制数1001对应的十进制数。计算如图所示:

3代码:(需要运用到数据结构栈的知识)

#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<iostream>
using namespace std;
#define MAXSIZE 100
#define ok 1
#define error 0
#define ovrflow -1 
typedef int status;
typedef struct{int *base;int *top;int stacksize;
}sqstack;
status initlist(sqstack &s);
void input(int x,int &e);
void conversion(sqstack &s,int y,int e);
void push(sqstack &s,int e);//改进 
int stackempty(sqstack s);
int pop(sqstack &s,int &e);
int main(){sqstack s;int x,y,m,e=0;while(1){cout<<"请决定将几进制转换为几进制:";cin>>x>>y;cout<<endl<<"请输入具体数值:";input(x,e);if(initlist(s)) cout<<"初始化成功"<<endl;else			cout<<"初始化失败";conversion(s,y,e);//栈,要转换的进制,元素 cout<<endl<<endl<<endl; }return 0;
}
status initlist(sqstack &s){//初始化 s.base=new int[MAXSIZE];if(!s.base) return error;s.top=s.base;s.stacksize=MAXSIZE;return ok;
}
void conversion(sqstack &s,int y,int e){//万物皆可十进制 x原先进制,y要转换的进制,m数值 while(e){push(s,e%y);e=e/y;}cout<<"转换成"<<y<<"进制为:";while(!stackempty(s)){pop(s,e);cout<<e;}
}
void input(int x,int &e){char a[20];scanf("%s",a);int c;c=strlen(a);cout<<endl;for(int i=0;i<c;i++){if(a[i]>='0'&&a[i]<='9')e+=((int)a[i]-48)*(int)pow(x,c-i-1);if(a[i]>='A'&&a[i]<='Y')e+=((int)a[i]-55)*(int)pow(x,c-i-1);}
}
void push(sqstack &s,int e){if(s.top-s.base==s.stacksize){cout<<"失败,栈满";}*s.top++=e;
}
int stackempty(sqstack s){if(s.top==s.base) return ok;return error;
}
int pop(sqstack &s,int &e){if(s.top==s.base) return error;e=*--s.top;return ok;
}
4运行结果:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法知识点汇总

知识点 1. 求二进制中1的个数 int get_count(int x)//返回x的二进制有多少个1 int get_count(int x) {int res 0;while (x){res ;x - x & -x;}return res; }2. 建树&#xff0c;和树的DFS 记得初始化头节点 const int N 1e5 10, M N * 2; int h[N], e[M], ne[M], id…

Golang和Java的对决:从设计理念到工具链的全面比较

文章目录 使用率排名Golang和Java设计理念语法和类型系统并发处理资源消耗生态系统和工具链 结语 使用率排名 据最新的2024年3月 Tiobe 编程语言排行榜&#xff0c;目前 Golang 的使用率排名为第8呈上升趋势&#xff0c;Java 的使用率排名为第4呈下降趋势 2024年3月2023年3月…

用ENIGMA-toolbox作图

之前一直使用ggseg呈现结果&#xff0c;最近想试一试其他绘图工具。ENIGMA-toolbox有所了解&#xff0c;绘图功能看起来门槛不高&#xff0c;所以就试着用它呈现一些结果。Matlab版本的ENIGMA-toolbox直接使用就是SurfStat的功能绘图&#xff0c;Python版本的绘图功能应该是根据…

【Leetcode】top 100 回溯

基础知识补充 回溯中的组合问题&#xff1a; 优化&#xff1a;剪枝&#xff1a;在for循环时需要根据当前状态调整循环次数&#xff08;组合问题&#xff09; 基础操作补充 &#xff01;&#xff01;&#xff01;牢记模板&#xff01;&#xff01;&#xff01; result [] def b…

UE4_破碎插件的蓝图节点_Apply Radius Damage

一、知识点 Apply Radius Damage:破碎组件所带的蓝图节点。 二、使用方法&#xff1a; 1、设置——插件&#xff0c;搜索destruction&#xff0c;找到 Apex Destruction&#xff0c;勾选已启用。重启虚幻编辑器。 2、这样右键操作就有创建可破坏的网格体菜单&#xff0c;将do…

八、从0开始卷出一个新项目之瑞萨RZN2L 3.1.7 debug调试和下载

目录 3.1.7 debug调试和下载 3.1.7.1 官方介绍 3.1.7.2 e2studio debug变量实时监控 3.1.7.3 Iar debug变量实时监控 3.1.7.4 debug经验总结 八、从0开始卷出一个新项目之瑞萨RZN2L 3.1.7 debug调试和下载 3.1.7 debug调试和下载 3.1.7.1 官方介绍 官网&#xff1a; d…

【国信华源2024年首场春季校园招聘面试会举办】

阳春三月&#xff0c;春意盎然&#xff0c;北京国信华源科技有限公司2024年校园招聘活动如期展开。4月2日&#xff0c;成功举办了“国信华源2024年首场春季校园招聘面试会”。 国信华源公司人力资源部热情接待了前来参加面试的同学们&#xff0c;并亲自陪同他们深入探访了企业。…

实操:driver.js 实现产品导览、亮点、上下文帮助

官网 https://driverjs.com/ 依赖 <script src"https://cdn.jsdelivr.net/npm/driver.js1.0.1/dist/driver.js.iife.js"></script> <link rel"stylesheet" href"https://cdn.jsdelivr.net/npm/driver.js1.0.1/dist/driver.css"/…

计蒜客3月普及组

Tutorial of Popularziation A 题出的不好 12 点到 1 点不会相交&#xff0c;24 点不计算 void solve(){int x, y, res;cin >> x >> y;res y - x;if(x < 11 && y > 12) res --;if(y 24) res --;cout << res << \n; }B 题解有问题…

使用mybatis拦截器日志打印sql执行时间(yml配置开关)

1.yml配置开关 monitoring:sql : true 2.拦截器实现 /*** author qujingye* Classname SqlStatementInterceptor* Description sql时间监控* Date 2024/4/3 14:56*/ Intercepts({Signature(type Executor.class, method "update", args {MappedStatement.class…

Apache DolphinScheduler 【安装部署】

前言 今天来学习一下 DolphinScheduler &#xff0c;这是一个任务调度工具&#xff0c;现在用的比较火爆。 1、安装部署 1.0、准备工作 1.0.1、集群规划 dolphinscheduler 比较吃内存&#xff0c;所以尽量给 master 节点多分配一点内存&#xff0c;桌面和虚拟机里能关的应用…

Spring Boot--文件上传和下载

文件上传和下载 前言文件上传1、以MultipartFile 接口流文件&#xff0c;流的名称需要和前台传过来的名称对应上2、获取到文件名称截取后缀3、为了放置文件名重复使用uuid来随机生成id后缀4、判断转存路径中是否有这个文件夹如果没有就创建5、将文件存储到转存的目录中 文件下载…

大宋咨询(深圳商业地产调查)房地产消费者问卷调查

面对复杂多变的地产市场&#xff0c;了解消费者的需求和偏好是至关重要的。通过进行消费者问卷调查&#xff0c;房地产开发商和营销人员可以收集到宝贵的数据&#xff0c;从而做出更明智的决策。下面将详细介绍大宋咨询&#xff08;深圳问卷调查公司&#xff09;如何进行房地产…

Android移动应用与开发上机实验报告

实验目的&#xff1a; 本项目需要开发一个Android App&#xff0c;运行后显示“欢迎XXX学习Android开发(第1行)、祝学有所成、马到成功&#xff01;(第2行)”。 根据该实验需求与实现思路(P26-27)&#xff0c;在获得素材的基础上&#xff0c;对手机主界面写代码进行实现&…

Java面试题:Java集合框架:请简述Java集合框架的主要组成部分,并解释它们之间的关系。

Java集合框架&#xff08;Java Collections Framework&#xff09;是一组用来表示和操作集合的类的集合&#xff0c;它提供了用于存储不同类型对象的标准化接口和类。Java集合框架的主要组成部分包括以下几个部分&#xff1a; 集合接口&#xff08;Collection Interface&#…

SpringBoot参数校验@Valid 和 @Validated注解使用详解

JSR-303 是 JAVA EE 6 中的一项子规范&#xff0c;叫做 Bean Validation&#xff0c;官方参考实现是Hibernate Validator。 注意&#xff1a;JSR-303实现与 Hibernate ORM 没有任何关系。 JSR 303 用于对 Java Bean 中的字段的值进行验证。 Spring MVC 3.x 之中也大力支持 JS…

web框架的本质初识

1.什么是HTML HTML是一个超文本语言&#xff0c;是一种创建网页结构的标记语言。就是你女朋友化妆之后的样子 2.什么是HTTP协议 是一种用于在Web上传输数据的协议。它是客户端和服务器之间进行相互通信的基础的协议 3.HTTP的特点 无连接&#xff1a;每个http请求都是独立的…

【WPF应用30】WPF中的ListBox控件详解

WPF&#xff08;Windows Presentation Foundation&#xff09;是.NET框架的一个组成部分&#xff0c;用于构建桌面应用程序的用户界面。ListBox是WPF中一个非常常用的控件&#xff0c;用于显示一系列的项&#xff0c;用户可以选择单个或多个项。 1.ListBox的基本概念 ListBox…

择校!这些计算机专业的考研学校性价比巨高(必看)

建议可以关注一下东北大学&#xff0c;可以抄底 今年东北大学刚更改408&#xff0c;加上地区不太优势&#xff0c;很可能爆冷&#xff0c;有时候会觉得学校的选择可能比个人的努力更加重要。要做出明智的选择&#xff0c;需要考虑近几年的复试分数线&#xff0c;以及当年的热度…

Neo4j基础知识

图数据库简介 图数据库是基于数学里图论的思想和算法而实现的高效处理复杂关系网络的新型数据库系统。它善于高效处理大量的、复杂的、互连的、多变的数据。其计算效率远远高于传统的关系型数据库。 在图形数据库当中&#xff0c;每个节点代表一个对象&#xff0c;节点之间的…