首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

【蓝桥杯备赛系列 | 简单题】十六进制八进制、十六进制十进制、十进制十六进制 (手撕)

为了刷题的本心,我们对应题目所需要求(进制转换 字符 循环),按照字符串来做(我觉得实现结果和BigInteger的构造函数可以参考) 1.2 字符串 算法实现 首先我们先观察十六进制和八进制、二进制。...其中十六进制每一个位对应 一个四位的二进制 每个八进制一个位对应 一个三位的二进制 那我们在这里的思想便是使用字符串对应 1.2.1 十六进制二进制 public static String HexToBinary...8位的正的十六进制字符串,将它转换为正的十进制数后输出。   ...四、总结 进制转换方法: 1、二进制八进制——取每三位按权相加。 2、二进制十六进制—取每四位按权相加。 3、二进制十进制——按权相加。...4、八进制二进制——转换字符串 6、十六进制二进制—同八进制,注意不足四位补0,去前导0. 7、十进制八进制——除八取余。 8、十进制十六进制—除十六取余。

2.4K40

基础练习 十六进制八进制

接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。 输出格式   输出n行,每行为输入对应的八进制正整数。...注意   输入的十六进制数不会有前导0,比如012A。   输出的八进制数也不能有前导0。...样例输入 2 39 123ABC 样例输出 71 4435274 思路:        如果先把十六进制转化成十进制,当十六进制数很大时,会溢出,若用字符串保存结果,那么八进制会极其复杂。...所以要先把十六进制转化成二进制,每四位十六进制数对应一个二进制数,再把二进制转化成八进制,每三个二进制数对应一个八进制数。...else t = s[i] - 'A' + 10; string tem; while(t) //十六进制二进制

1.4K20

基础练习 十六进制八进制

问题描述   给定n个十六进制正整数,输出它们对应的八进制数。 输入格式   输入的第一行为一个正整数n (1<=n<=10)。   ...接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。 输出格式   输出n行,每行为输入对应的八进制正整数。   ...【注意】   输入的十六进制数不会有前导0,比如012A。   输出的八进制数也不能有前导0。.../* * Binary是0-15的二进制数的数组 * Octal是0-7的二进制数的水族 * map是0-7与其二进制数的映射 */ //16进制2...Binary[(int)(ch-'A')+10]); } } return binary.toString(); } //2进制8

60800

十进制十六进制 C++

题目描述 编写一个函数,传入一个十进制的正整数,将十进制整数转换为十六进制字符串并返回。...(十六进制字符串中的字母全部大写) 输入描述: 键盘输入一个十进制的正整数 输出描述: 输出该十进制整数转换后的十六进制字符串 示例1 输入: 162 复制输出: A2 复制 示例2 输入: 50 复制输出...: 32 复制 示例3 输入: 501 复制输出: 1F5 思路分析 思路很简单,就是按照十进制十六进制的算法来算,除以16取余,关键是灵活调用string类的各种函数来完成插入的工作。...具体来说: 先建立一个空的string字符串hex用来存储我们变换后的十六进制数,之后我们对十进制数进行除以16取余的操作,这里需要一个循环,先判断和16取余后的数是否小于10,如果小于10,说明是数字...,加上‘0’就可以变成相应的数字字符,如果不是小于10,说明要变成字母,加上‘A'就可以变成相应的字母了,然后将该字符用insert函数插入字符串hex的开头,然后将十进制数除以16后继续循环,直到十进制数为

26830
领券