//

//  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. HTML中为何P标签内不可包含块元素?

    起因:在做项目时发现原本在DW中无误的代码到了MyEclipse6.0里面却提示N多错误,甚是诧异.于是究其原因,发现块级元素P内是不能嵌套DIV的. 深究:我们先来认识in-line内联元素和blo ...

  2. NOJ 1641 错误的算法(模拟)

    [1641] 错误的算法 时间限制: 5000 ms 内存限制: 65535 K 问题描述 有道题目是这样的: 输入一个 n 行 m 列网格,找一个格子,使得它所在的行和列中所有格子的数之和最大.如果 ...

  3. 使用CodeIgniter框架搭建RESTful API服务

    使用CodeIgniter框架搭建RESTful API服务 发表于 2014-07-12   |   分类于 翻译笔记   |   6条评论 在2011年8月的时候,我写了一篇博客<使用Cod ...

  4. PHP IDE phpstorm 常用快捷键

    PHP IDE phpstorm 常用快捷键 投稿:junjie 字体:[增加 减小] 类型:转载   这篇文章主要介绍了PHP IDE phpstorm 常用快捷键,本文分别列出了mac系统和Win ...

  5. file_get_contents无法获取数据的一种情况

    下面这段php代码突然不好使了,返回的 $html 为空,百思不得解.网上说法好多,但都是一家之言,解决不了我的问题.(我的解决方法也是一家之言,只能解决file_get_contents获取不到数据 ...

  6. vector 初始化所有方法

    简介:vector可用于代替C中的数组,或者MFC中的CArray,从许多说明文档或者网上评论,一般一致认为应该多用vector,因为它的效率更高,而且具备很好的异常安全性.而且vector是STL推 ...

  7. 捕获JS 错误日志

    最近在做项目的过程中,发现很多JS报错没有引起重视,我就想想把JS错误捕获了,然后展示在我们一个平台上 具体实现代码: window.onerror = function(message, url,  ...

  8. CC254x(cc2540/cc2541)的微信AirSync调试笔记

    一.前言 本尊自诩为IOT小能手,一直没涉足蓝牙实在说不过去.刚好上个月底的时候计划做个BLE设备,这阵子利用业余时间自学了BLE协议栈,了解了GATT,磕磕绊绊完成CC254x(cc2540/cc2 ...

  9. hive中的常用方法(case,cast,unix_timestamp)

    1.case的用法 )格式1 case col when value then '' when value then '' else '' end )格式2 case when col='value' ...

  10. Github简明教程(转)

    原文地址 : http://wuyuans.com/2012/05/github-simple-tutorial/ github是一个基于git的代码托管平台,付费用户可以建私人仓库,我们一般的免费用 ...