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# 十进制与二进制、十六进制、八进制之间的转换的更多相关文章

  1. PHP函数篇详解十进制、二进制、八进制和十六进制转换函数说明

    PHP函数篇详解十进制.二进制.八进制和十六进制转换函数说明 作者: 字体:[增加 减小] 类型:转载   中文字符编码研究系列第一期,PHP函数篇详解十进制.二进制.八进制和十六进制互相转换函数说明 ...

  2. PHP函数十进制、二进制、八进制和十六进制转换

    PHP函数篇详解十进制.二进制.八进制和十六进制互相转换函数说明,主要掌握各进制转换的方法,以应用于实际开发. 一,十进制(decimal system)转换函数说明 1,十进制转二进制 decbin ...

  3. PHP:第一章——PHP中十进制、二进制、八进制、十六进制转换

    //十进制.二进制.八进制.十六进制转换 //十进制转换为二进制decbin()函数: //echo decbin(5);//输出:101 //十进制转换为八进制decoct()函数 //echo d ...

  4. PHP函数十进制、二进制、八进制和十六进制转换函数说明

    1.十进制转二进制 decbin() 函数,如下实例  echo decbin(12); //输出 1100 echo decbin(26); //输出 11010 2.十进制转八进制 decoct( ...

  5. C++进制转换(十进制转二进制、八进制、随意进制)

    十进制转二进制: //十进制转二进制 #include<iostream> using namespace std; void printbinary(const unsigned int ...

  6. c#二进制、十进制、16进制之间的转换

    //十进制转二进制 Console.WriteLine(Convert.ToString(69, 2)); //十进制转八进制 Console.WriteLine(Convert.ToString(6 ...

  7. 【转】Javabyte[]数组和十六进制String之间的转换Util------包含案例和代码

    原文网址:http://blog.csdn.net/caijunjun1006/article/details/11740223 Java中byte用二进制表示占用8位,而我们知道16进制的每个字符需 ...

  8. Javabyte[]数组和十六进制String之间的转换Util------包含案例和代码

    Java中byte用二进制表示占用8位,而我们知道16进制的每个字符需要用4位二进制位来表示(23 + 22 + 21 + 20 = 15),所以我们就可以把每个byte转换成两个相应的16进制字符, ...

  9. Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)

    使用Python内置函数:bin().oct().int().hex()可实现进制转换. 先看Python官方文档中对这几个内置函数的描述: bin(x)Convert an integer numb ...

随机推荐

  1. UWP_开源小程序 水印添加器

    前几天写了一个确定水印位置的小博客.决定要写一个添加水印的UWP程序. 目前程序技术方面已经差不多了.所以提上日程

  2. 图像特征提取之Haar特征

    1.Haar-like特征 Haar-like特征最早是由Papageorgiou等应用于人脸表示,Viola和Jones在此基础上,使用3种类型4种形式的特征. Haar特征分为三类:边缘特征.线性 ...

  3. AISing Programming Contest 2019C(DFS,BFS)

    #include<bits/stdc++.h>using namespace std;int n,m;long long a=0,b=0,ans=0;char s[407][407];in ...

  4. VMWare 装mac os x 一个必备优化神器 beamoff

    https://blog.csdn.net/whitehack/article/details/47074403/ VMWare 装mac os x 一个必备优化神器 beamoff 2015年07月 ...

  5. zabbix发送邮件脚本

    #!/usr/bin/env python #-*- coding: UTF- -*- import os,sys reload(sys) sys.setdefaultencoding('utf8') ...

  6. VC对话框的菜单设置变灰, 打勾 等

    一般可以用UPDATE_COMMAND_UI消息,并加入以下代码:pCmdUI->Enable(FALSE); 就实现,弹对话框的菜单需要增加对WM_INITMENUPOPUP消息的处理以后,才 ...

  7. react 的安装和案列Todolist

    react 的安装和案列Todolist 1.react的安装和环境的配置 首先检查有没有安装node.js和npm node -v npm -v 查看相关版本 2.安装脚手架工具 2.构建:crea ...

  8. [Node.jS]shelljs

    shelljs : https://www.npmjs.org/package/shelljs 要给可以替代Unix下shell脚本的库. require('shelljs/global'); if ...

  9. ZOJ3068(01分数规划)

    本是POJ2976,喜闻乐见的01规划入门题.POJ日常假死,到ZOJ测. 二分答案. 试了试数据好像没问题,\(a_i\)总是小于\(b_i\)且最终预答案l都小于1.然而为什么我把r设成1e10往 ...

  10. Life is a journey

    Life is a journey. What we should care about is not where it's headed but what we see and how we fee ...