C# 十进制与二进制、十六进制、八进制之间的转换
1.十进制 转 二进制
将十进制数不断地除2,将所有余数倒叙填写,即可得到所需二进制数据。
public static string DecimalToBinary(int vDecimal)
{
/* 将十进制的数 vDecimal 不断地除 2,取余数
* 然后将余数 倒序 填写
*/
List<int> vYuShu = new List<int>(); // 除 2 过程中产生的余数集
int vTempValue= vDecimal; // 除 2 过程中产生的商数
for (; ; )
{
int tempYS = vTempValue % ;
vYuShu.Add(tempYS); // 记住余数 vTempValue = vTempValue / ;
if (vTempValue == ) // 商数等于0时,结束运算
break;
}
// 倒序输出
string strBinary = "";
for (int i = vYuShu.Count - ; i >= ; i--)
{
strBinary += vYuShu[i];
} Console.WriteLine("Input decimal value:{0}, output binary value:{1}.", vDecimal, strBinary); return strBinary;
}

2. 二进制 转 十进制
将二进制各位上的值(0或1)乘2的(n-1)次方,将每位结果相加。其中,n表示二进制中从右向左的位数(从1开始计);
public static int BinaryToDecimal(string vBinary)
{
// 首先判断是否满足输入要求
int[] vInput = new int[vBinary.Length];
for (int i = ; i < vBinary.Length; i++)
{
var tempNum = vBinary[i].ToString();
if (tempNum == "")
{
vInput[i] = ;
}
else if (tempNum == "")
{
vInput[i] = ;
}
else
{
throw new Exception("输入参数不正确,二进制数应仅由:0和1组成");
}
}
/*
* 依次乘2的(n-1)次方,再求和
*/
int vDecimal = ;
for (int i = ; i <= vInput.Length; i++)
{
vDecimal += (int)(Math.Pow(, i - ) * vInput[vInput.Length-i]);
} Console.WriteLine("Input binary value:{0}, output decimal value:{1}.", vBinary, vDecimal); return vDecimal;
}

3. 自带的转换方式
C#.Net自带的进制转换方式:
int vDecimal = ;
// 【10】 → 【2】
string vBinary = Convert.ToString(vDecimal, 2);
Console.WriteLine("十进制数:{0},转换成二进制:{1}", vDecimal, vBinary); // 【2】 → 【10】
int tempDecimal = Convert.ToInt32(vBinary, 2);
Console.WriteLine("二进制数:{0},转换成十进制:{1}", vBinary, tempDecimal);

4. 十进制 <=> 十六进制
int vDecimal = ;
// 【10】 → 【16】
string vStrHex = "0x" + Convert.ToString(vDecimal, 16);
Console.WriteLine("十进制数:{0},转换成十六进制:{1}", vDecimal, vStrHex); // 【16】 → 【10】
int tempDecimal = Convert.ToInt32(vStrHex, 16);
Console.WriteLine("十六进制数:{0},转换成十进制:{1}", vStrHex, tempDecimal);

或者可以:

5. 十进制 <=> 八进制

6. 其它转换

7. 有符号的数 二进制转换
对于有正负号的数据,在转换时与上诉略有不同。
1个字节(8个bits)它不管怎么样还是只能表示256个数,因为有符号所以我们就把它表示成范围:-128 → 127。
用最高位表示符号位,0表示正数,1表示负数。
10000000在计算机中表示最小的负整数。从10000001到 11111111依次表示-127到-1。
负整数在计算机中是以补码形式储存的。
public static int BinaryToDecimalWithSign(string vBinary)
{
// 首先判断是否满足输入要求
int[] vInput = new int[vBinary.Length];
for (int i = ; i < vBinary.Length; i++)
{
var tempNum = vBinary[i].ToString();
if (tempNum == "")
{
vInput[i] = ;
}
else if (tempNum == "")
{
vInput[i] = ;
}
else
{
throw new Exception("输入参数不正确,二进制数应仅由:0和1组成");
}
}
// -------- 不足8bits,补足 --------(非必需)
if (vInput.Length % != ) // 补足8b、16b、、、
{
int nLen = (vInput.Length / + ) * ;
int[] nInput = new int[nLen];
for (int i = ; i < nLen - vInput.Length; i++)
{
nInput[i] = vInput[];
}
vInput.CopyTo(nInput, nLen - vInput.Length); vInput = nInput;
}
// --------------------------------- // 第1步:首位为1,则为负值
int vFH = vInput[];
if (vFH == )
{
// ---------- 第2步:减去一 ----------
for (int i = ; i <= vInput.Length; i++)
{
if (vInput[vInput.Length - i] == )
{
vInput[vInput.Length - i] = ;
break;
}
else
{
vInput[vInput.Length - i] = ;
}
} // ---------- 第3步:取反 ----------
for (int i = ; i < vInput.Length; i++)
{
vInput[i] = - vInput[i];
}
}
// ---------- 第4步:转成10进制数 ----------
int vDecimal = ;
for (int i = ; i <= vInput.Length; i++)
{
vDecimal += (int)(Math.Pow(, i - ) * vInput[vInput.Length - i]);
}
if (vFH == ) // 为负数
{
vDecimal = - vDecimal;
} Console.WriteLine("Input binary value:{0}, output decimal value:{1}.", vBinary, vDecimal); return vDecimal;
}

[http://www.cnblogs.com/CUIT-DX037/]
C# 十进制与二进制、十六进制、八进制之间的转换的更多相关文章
- PHP函数篇详解十进制、二进制、八进制和十六进制转换函数说明
PHP函数篇详解十进制.二进制.八进制和十六进制转换函数说明 作者: 字体:[增加 减小] 类型:转载 中文字符编码研究系列第一期,PHP函数篇详解十进制.二进制.八进制和十六进制互相转换函数说明 ...
- PHP函数十进制、二进制、八进制和十六进制转换
PHP函数篇详解十进制.二进制.八进制和十六进制互相转换函数说明,主要掌握各进制转换的方法,以应用于实际开发. 一,十进制(decimal system)转换函数说明 1,十进制转二进制 decbin ...
- PHP:第一章——PHP中十进制、二进制、八进制、十六进制转换
//十进制.二进制.八进制.十六进制转换 //十进制转换为二进制decbin()函数: //echo decbin(5);//输出:101 //十进制转换为八进制decoct()函数 //echo d ...
- PHP函数十进制、二进制、八进制和十六进制转换函数说明
1.十进制转二进制 decbin() 函数,如下实例 echo decbin(12); //输出 1100 echo decbin(26); //输出 11010 2.十进制转八进制 decoct( ...
- C++进制转换(十进制转二进制、八进制、随意进制)
十进制转二进制: //十进制转二进制 #include<iostream> using namespace std; void printbinary(const unsigned int ...
- c#二进制、十进制、16进制之间的转换
//十进制转二进制 Console.WriteLine(Convert.ToString(69, 2)); //十进制转八进制 Console.WriteLine(Convert.ToString(6 ...
- 【转】Javabyte[]数组和十六进制String之间的转换Util------包含案例和代码
原文网址:http://blog.csdn.net/caijunjun1006/article/details/11740223 Java中byte用二进制表示占用8位,而我们知道16进制的每个字符需 ...
- Javabyte[]数组和十六进制String之间的转换Util------包含案例和代码
Java中byte用二进制表示占用8位,而我们知道16进制的每个字符需要用4位二进制位来表示(23 + 22 + 21 + 20 = 15),所以我们就可以把每个byte转换成两个相应的16进制字符, ...
- Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)
使用Python内置函数:bin().oct().int().hex()可实现进制转换. 先看Python官方文档中对这几个内置函数的描述: bin(x)Convert an integer numb ...
随机推荐
- UINavigationController + UIScrollView组合,视图尺寸的设置探秘(三)
还是在苹果的 View Controller Catalog for iOS 文章中找到答案.文中提到了两点: 1.If the navigation bar or toolbar are visib ...
- loj #2006. 「SCOI2015」小凸玩矩阵
#2006. 「SCOI2015」小凸玩矩阵 题目描述 小凸和小方是好朋友,小方给小凸一个 N×M N \times MN×M(N≤M N \leq MN≤M)的矩阵 A AA,要求小凸从其中选出 ...
- 洛谷P3301 [SDOI2013]方程(扩展Lucas+组合计数)
题面 传送门 题解 为啥全世界除了我都会\(exLucas\)啊--然而我连中国剩余定理都不会orz 不知道\(exLucas\)是什么的可以去看看yx巨巨的这篇博客->这里 好了现在我们就解决 ...
- 树莓派编译安装 FFmpeg(添加 H.264 硬件编解码器支持)
说明 FFmpeg 是一套开源的音视频编解码库,有非常强大的功能,包括视频采集功能.视频格式转换等.众所周知视频编解码是一个非常消耗系统资源的过程,而树莓派自带了 H.264 的硬件编解码器,因此本文 ...
- List<T>中 GetRange (int index, int count)的使用
GetRange:在源 List<T> 中创建元素范围的浅表复制. ; ) { List<T> uplist = new List<T>(); u++; <= ...
- [Leetcode]015. 3Sum
public class Solution { public List<List<Integer>> threeSum(int[] num) { Arrays.sort(num ...
- Ubuntu系统中连接TFS的Git地址注意事项
在Ubuntu中安装Git后,配置远程Git服务器地址,如果是TFS的Git仓库地址,则需要使用IP地址,否则可能出现识别不出来的问题; 再者,如果你想要在Ubuntu的浏览中访问TFS的Git仓库U ...
- sharepoint_study_10
描述:想页面添加一段脚本效果如图所示 图示: 代码(脚本编辑器): <div class="index-links"> <a class=" index ...
- CodeForces-Zuhair and Strings(思维+枚举)
Given a string ss of length nn and integer kk (1≤k≤n1≤k≤n). The string ss has a level xx, if xx is l ...
- 基本数据类型 list and tuple 04
列表和元组 一,列表 1.列表 由[]括起来 可以存放各种数据类型: 存放量比较大 2.列表的索引和切片 列表也有索引 lst [i] i 即列表中各元素的位置 2.1列表的切片 lst[star ...