//

//  main.c

//  Hex conversion

//

//  Created by ma c on 15/7/22.

//  Copyright (c) 2015年 bjsxt. All rights reserved.

//  要求:十进制向任意进制之间的转换(查表法)。

#include <stdio.h>

//十六进制的转换

void ToHex(int num)

{

int temp;

char chs[8];//定义一个临时容器,长度为8,8X4=32位比特

int pos=8;  //定义一个索引

char ch[] = {'0','1','2','3',

'4','5','6','7',

'8','9','a','b',

'c','d','e','f'};

printf("%d的十六进制是:",num);

while(num!=0)

{

temp = num & 15;

chs[--pos]= ch[temp];     //将查表中的数据存放到临时容器中。

num = num >> 4;           //向左移动次低四位

};

for(int x=pos;x<8;x++)

{

printf("%c",chs[x]);

}

printf("\n");

}

//八进制的转换

void ToOct(int num)

{

int temp;

char chs[11];//定义一个临时容器

int pos=11;  //定义一个索引

char ch[] = {'0','1','2','3',

'4','5','6','7',

'8','9','a','b',

'c','d','e','f'};

printf("%d的八进制是:",num);

while(num!=0)

{

temp = num & 7;

chs[--pos]= ch[temp];     //将查表中的数据存放到临时容器中。

num = num >> 3;           //向左移动次低三位

};

for(int x=pos;x<11;x++)

{

printf("%c",chs[x]);

}

printf("\n");

}

//二进制的转换

void ToBinary(int num)

{

int temp;

char chs[32];//定义一个临时容器

int pos=32;  //定义一个索引

char ch[] = {'0','1','2','3',

'4','5','6','7',

'8','9','a','b',

'c','d','e','f'};

printf("%d的二进制是:",num);

while(num!=0)

{

temp = num & 1;

chs[--pos]= ch[temp];     //将查表中的数据存放到临时容器中。

num = num >> 1;           //向左移动次低一位

};

for(int x=pos;x<32;x++)

{

printf("%c",chs[x]);

}

printf("\n");

}

int main(int argc, const char * argv[])

{

ToHex(60);

ToOct(60);

ToBinary(60);

printf("\n");

return 0;

}

C语言:十进制进制转换为其他进制(思想:查表法)的更多相关文章

  1. 16进制字符串和byte数组进行相互转换\将10进制转换为任意进制

    16进制字符串和byte数组进行相互转换 简介 1个byte对应8个bit,16进制使用4个bit,所以一个byte转成16进制,占用两位. JAVA代码 private static final c ...

  2. 从M进制转换为N进制

    /// <summary> /// 从M进制转换为N进制 /// </summary> internal class MBase2NBase { /// <summary ...

  3. Java 二维数组,排序、切换顺序,查表法二进制十进制,这班查找、排序(冒泡、选择)、遍历,获取最大小值(4)

    Java 二维数组,排序.切换顺序,查表法二进制十进制,折半查找.排序(冒泡.选择).遍历,获取最大小值(4)

  4. 【C语言学习笔记】空间换时间,查表法的经典例子!知识就是这么学到的~

    我们怎么衡量一个函数/代码块/算法的优劣呢?这需要从多个角度看待.本篇笔记我们先不考虑代码可读性.规范性.可移植性那些角度. 在我们嵌入式中,我们需要根据实际资源的情况来设计我们的代码.比如当我们能用 ...

  5. java学习进制转换之查表法

    10进制转16进制,以及10进制转2进制,还有10进制转8进制,这些转换如果按照常规思路的话,会灰常的麻烦. 我们来看一下 10进制转16进制: 假如这里有一个十进制数字:35,我们的需求就是把这个3 ...

  6. 十进制和n进制的转换(10进制转换为36进制)

    答案如下: void Convert() { map<int ,string> maps; maps[0]="0"; maps[1]="1"; ma ...

  7. lua之m进制转换为n进制-任意进制转换算法

    够无聊的写这个,为防止需要的人也无聊一遍,写个吧 算法有n种,但是,咱们一种就够用了 --数组倒序排列 local function orderByDesc( input ) local output ...

  8. Java查表法实现十进制转化成其它进制

    首先了解十进制转化成二级制的原理 156的二进制为: 156 % 2 = 78 …… 0 83 % 2 = 39 …… 0 39 % 2 = 19 …… 1 19 % 2 = 9 …… 1 9 % 2 ...

  9. YUV420查表法高效、无失真的转换为RGB32格式

    YUV格式有两大类:planar和packed.planar的YUV格式,先连续存储所有像素点的Y,紧接着存储所有像素点的U,随后是所有像素点的V,这里所讲述的就是这中存储格式的:packed的YUV ...

随机推荐

  1. Genymotion填坑之路

    Genymotion是一款android的模拟器,之前用的一台电脑直接装上就可以用,后来换了一台机器,一直报获取不到IP,后来网上各种找方法,偶然发现网上说的是硬件问题: 在BIOS中将CPU的vir ...

  2. iOS完整学习步骤

    一  C语言 1.1基本数据类型和基本运算 1.2 函数 数组 字符串 指针 1.3 预处理指令 1.4结构体 枚举 1.5 文件操作 内存管理 二 Objective - C 2.1 面向对象 2. ...

  3. [转] - C++程序启动过程

    先说编译.链接过程1.预编译展开宏2.为每一个.cxx源文件编译一个目标文件3.编译器合成这些目标文件成一个库文件,同时解析可以找到的符号引用4.连接器把目标的库文件和所需要的引用的静.动态链接库进行 ...

  4. mysql安装后的配置

    mysql的安装其实就是一步一步按提示就可以: 1.开始安装 2.选择mysql安装位置 3.选择数据库存放位置,最好和mysql安装在一起,好查找 4.选择详细设置 5.选开发者机器 6.选多功能型 ...

  5. Shrink磁盘

      30857(分区的总容量) =  10160(可修改的这个10610表示Shrink之后的空闲分区) + 20697(Shrink之后分区中占用掉的容量)

  6. 根据CSV找出USBGroup中计算机对应的用户

    <USB.CSV> Hostname,Username CNHZPD-TEST1,User1 CNHZLN-01234567,User2   $group = "CN=Enabl ...

  7. Word 2013双引号的BUG

    相信使用Word 2013的朋友大多碰到过这样一个双引号的bug: 问题详细描述: word2013中,打字时引号出现问题,在输入中文情况下,输入左引号为中文,输入右引号时会自动变成英文.微软自己的输 ...

  8. Linux 计划任务 Crontab 笔记与总结(1)

    Linux 版本:CentOS 6.6 应用场景,例如: ① 每分钟执行一个程序检查系统运行状态 ② 每天凌晨需要对过去一天的业务数据进行统计 ③ 每个星期需要把日志文件备份 ④ 每个月把数据库进行备 ...

  9. Python装饰器与面向切面编程

    今天来讨论一下装饰器.装饰器是一个很著名的设计模式,经常被用于有切面需求的场景,较为经典的有插入日志.性能测试.事务处理等.装饰器是解决这类问题的绝佳设计,有了装饰器,我们就可以抽离出大量函数中与函数 ...

  10. ExpandableListView实现子Item的点击事件

    在继承的BaseExpandableListAdapter的ExpandableListView的Adapter中,重写以下方法 @Override public boolean isChildSel ...