C语言之进制

进制

一种计数的方式.侧重点在于计数的时候是逢多少进一.

1)      C语言可以识别的进制

  1. 二进制

      每一位. 0 0 1 0 0 1 1 0 1 0 1 0 0 1 0 1 1 0

      在C语言中,写一个二进制的数的方式就是在前面加一个 0b或者0B的前缀,二进制每一位是0或者1,逢2进1;

  2. 八进制

      每一位. 0 1 2 3 4 5 6 7 10 11

      在C语言中,写一个八进制的数的方式就是在前面加一个 0的前缀,逢8进1;

%o    将整型变量中得数据以八进制的形式输出

  3. 十进制

      每一位. 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14

       在C语言中直接写1个整数,那么默认就是十进制,逢10进1;

      %d    将整型变量中得数据以十进制的形式输出

  4. 十六进制

      每一位. 0 1 2 3 4 5 6 7 8 9 a b c d e f 10 11 12

      在C语言中,写一个十六进制的数的方式就是在前面加一个 0x或者0X的前缀,逢16进1;

%x    将整型变量中得数据以八进制的形式输出

2).进制之间的转换

a. 基本概念

数码: 指的是这个数据的每一位的数字.

数位: 数码在这个数中的位置.从右到左.依次递增从 0 开始.

基数: 就是每一个数码可以有多少个数据来表示.

(基数其实指的就是这个数的进制).

位权: 数码乘以(基数的数位次方)

任何数的0次方都为1.

b. 十进制转换为二进制

除2取余法. 将这个数除以2. 直到商为1或者0. 然后最后1个商和所有余数倒序. 就是这个十进制对应的二进制.

例:

10 的二进制是 1010

178 的二进制是10110010

c. 二进制转换为十进制

加权法:将这个二进制数的每个数码的位权相加,就是这个二进制对应的十进制.

10101  每1个数码的位权相加.

第0位的位权: 1 * 2的0次方    1

1      *                    0

2      *                    4

3      *                    0

4        *                  16

d.      十进制转换为八进制

除8取余(与十进制转换为二进制方法类似)

e.      八进制转换为十进制

加权法:将八进制的每1个数码的位权相加 得到的就是其对应的十进制数.

0342

第0位: 2 * 8的0次方  2

1     4 * 8的1      32

2     3 * 8的2     192

f. 二进制转换为八进制.

三合一法则:将这个二进制从低位到高位每三位分成1组.高位不够补0将每1组转换为十进制.最后将每1组的十进制连起来. 就是这个二进制对应的八进制.

001 011 100 110 011

1    3   4    6   3

g. 八进制转换为二进制.

一拆三:将这个八进制数的没1个数码拆为1个三位的二进制数.把这些二进制数连起来.

134674

001 011 100 110 111 100

h. 二进制转换为十六进制.

四合一法则:将这个二进制从低位到高位每四位分成1组.高位不够补0

将每1组转换为对应的十六进制.最后将每1组转换成功的十六进制数链接起来.

11100101010111110111101010101

0001 1100 1010 1011 1110 1111 0101 0101

1    c    a     b     e     f      5    5

k. 十六进制转换为二进制.

一拆四法则:将这个十六进制的书的每1个数码拆为1个四位的二进制数,将其连起来.

4dea761;

0100 1101 1110 1010 0111 0110 0001

时间: 2024-10-07 11:15:13

C语言之进制的相关文章

2.4.2-Java语言基础(进制转换)

二进制转成十进制 八进制.十六进制转成十进制 二进制转成八进制.十六进制 八进制.十六进制转成二进制 八进制转成十六进制 十六进制转成八进制 十进制转成二进制.八进制.十六进制 ?  负数的二进制表现形式 ?  对应的正数二进制取反加1 2.4.2-Java语言基础(进制转换)

C语言中进制知识总结

1.什么是进制 进制是一种计数的方式,常用的有二进制.八进制.十进制.十六进制.任何数据在计算机内存中都是以二进制的形式存放的. 我对进制的个人理解,二进制数是以2为计算单元,满2进1位的数:八进制数是以8为计算单元,满8进1位的数. 对于任何一个数字,我们都可以用不同的进制来表示,比如,十进制数12,用二进制表示为1100,用八进制表示为14,用十六进制表示为0xC. 2.进制的转换规则 遵循满进制值进1位,个位数变为0的原理,下面我们以十进制数18为例,对1-18中每一个数值转换各种进制做一

新手第一天学习 C#语言(进制互换)

说起来我们对一些陌生或者未知的东西有一些恐惧感,但是又有一些期待,虽然我不确定自己能不能学会这门语言,但是我会尽自己最大的努力学. 我们第一天学的的内容呢,对大多数的人都知道,计算机的语言是二进制,但是生活中我们用的是十进制.那要怎么换算二进制呢? 比如一个例子:     我有个数字72 (十进制)   换成 二进制 72  除以2   得商   为  36  18  9  4  2  1 所得余数  为   0     0   1  0  0  1 那么从左到右写   为   1   0  0

一起talk C栗子吧(第七回:C语言实例--进制转换)

各位看官们.大家好,从今天開始.我们讲大型章回体科技小说 :C栗子,也就是C语言实例. 闲话休提, 言归正转.让我们一起talk C栗子吧! 看官们.上一回中咱们说的是生成随机数的样例.这一回咱们说的样例是:进制转换.说到进制预计大家 都不陌生.计算机中的进制有二进制.八进制,十进制,十六进制. 今天咱们将要说的是十进制怎样转换成二进制.八进制和十六进制.在这里我把敲代码的步骤和算法思路 写出来供大家參考. 1.获取用户想要转换的数值和想到转换的进制.这里要检查输入是否正确.这是程序健壮性的体现

C语言编写进制转化

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "PingFang SC"; color: #454545 } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Helvetica; color: #454545 } span.s1 { font: 12.0px Helvetica } span.s2 { font: 12.0px "PingFang SC&quo

c语言之进制转换(栈实现)

从上两篇博客中我们可以知道,栈具有后进先出的特性,而进制转换的打印输出刚好与计算过程相反,满足栈这后进先出的特性, 所以可以用栈很快的实现进制转换,下面是用栈实现进制转换的c函数 void conversion (SqStack *pstack,unsigned int N, const unsigned int d){ if( pstack == NULL)//当传入参数为指针,必须判空 exit(-1); int mod ;//保存mod = N %d while( N != 0){ mod

C语言实现进制转换

#include<stdio.h> int main() {     char ku[16]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};     int zh[32],i=0,w,j;     long int b,y;     printf("请输入一个十进制数,我能帮您把它转换成2~16任意进制数:\n");     scanf("%d",&y);   

【学习ios之路:C语言】进制.位运算.栈

1.进制转换 1).10进制转为N进制.方法:(连除倒取余). 2).N进制转换为10进制.方法:(按权求和法):当前位上的数乘以基数的位数减1次方. 例: 0b1111 ---- 1* 2^3 + 1*2^2 +1 * 2^1 +1*2^0 = 15; 038 ----- 3*16^1 +8*16^0 = 56; 3).N进制转换N进制. 例如: 二进制 --- 16进制 1010   0011  ----  A 3 1111   0011  ----  F 3 int a = 010;//8

【学习笔记】【C语言】进制

1. 什么是进制 是一种计数的方式,数值的表示形式 2. 二进制 1> 特点:只有0和1,逢2进1 2> 书写格式:0b或者0b开头 3> 使用场合:二进制指令\二进制文件,变量在内存中就是二进制存储 4> 二进制和十进制的互相转换 5> n为二进制位所能表示的数据范围(不考虑负数):0~2的n次方-1 3. 八进制 1> 特点:0~7,逢八进一 2> 书写格式:0开头 3> 八进制和二进制的互相转换 4. 十六进制 1> 特点:0~F,逢十六进一 2