求16进制转10进制;BYTE的算法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求16进制转10进制;BYTE的算法相关的知识,希望对你有一定的参考价值。
普通的二进制算法,还会计算。请问9A(H)怎样转换成最后的那个-102(D)的?(最后的两个窗口)请问这种计算结果,能手写计算吗?或是BYTE和他们的关系是什么。谢谢!
参考技术A 十六进制转十进制,是把各个数字乘以它们的计数单位来算的,根本用不着按字节来算,例如:十六进制下的9A,这里的A相当于10,而这里的9实际上是九个16,也就是16乘以9,得144,加10,就是154,而不是-102。本回答被提问者采纳 参考技术B 9Ah = 1001 1010b如果按照有符号数(补码)解析,因为最高位是符号位,因此这是个负数。
补码 = 反码+1,即 0110 0101b + 1b = 0110 0110b = 66h = 102。
另一种算法是补码负数的绝对值 = 满范围 - 补码,即100h - 9Ah = 66h = 102。
任何一本计算机教材或者C语言教材,刚开始介绍二进制及基础运算的部分,都会有。
华为OJ084-求最大连续bit数
【华为OJ】【算法总篇章】
【华为OJ】【084-求最大连续bit数】
【工程下载】
题目描述
功能: 求一个byte数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1
输入: 一个byte型的数字
输出: 无
返回: 对应的二进制数字中1的最大连续数
输入描述
输入一个byte数字
输出描述
输出转成二进制之后连续1的个数
输入例子
3
输出例子
2
算法实现
import java.util.Scanner;
/**
* Author: 王俊超
* Date: 2016-01-04 09:44
* Declaration: All Rights Reserved !!!
*/
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
// Scanner scanner = new Scanner(Main.class.getClassLoader().getResourceAsStream("data.txt"));
while (scanner.hasNext()) {
int b = scanner.nextInt();
System.out.println(countBit(b));
}
scanner.close();
}
private static int countBit(int b) {
int max = 0;
int cur = 0;
b &= 0xFF;
for (int i = 0, and = 1; i < 8; i++) {
// 如果第i位为1
if ((b & and) != 0) {
cur++;
if (cur > max) {
max = cur;
}
} else {
cur = 0;
}
and <<= 1;
}
return max;
}
}
以上是关于求16进制转10进制;BYTE的算法的主要内容,如果未能解决你的问题,请参考以下文章