C语言:十进制进制转换为其他进制(思想:查表法)
//
// 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语言:十进制进制转换为其他进制(思想:查表法)的更多相关文章
- 16进制字符串和byte数组进行相互转换\将10进制转换为任意进制
16进制字符串和byte数组进行相互转换 简介 1个byte对应8个bit,16进制使用4个bit,所以一个byte转成16进制,占用两位. JAVA代码 private static final c ...
- 从M进制转换为N进制
/// <summary> /// 从M进制转换为N进制 /// </summary> internal class MBase2NBase { /// <summary ...
- Java 二维数组,排序、切换顺序,查表法二进制十进制,这班查找、排序(冒泡、选择)、遍历,获取最大小值(4)
Java 二维数组,排序.切换顺序,查表法二进制十进制,折半查找.排序(冒泡.选择).遍历,获取最大小值(4)
- 【C语言学习笔记】空间换时间,查表法的经典例子!知识就是这么学到的~
我们怎么衡量一个函数/代码块/算法的优劣呢?这需要从多个角度看待.本篇笔记我们先不考虑代码可读性.规范性.可移植性那些角度. 在我们嵌入式中,我们需要根据实际资源的情况来设计我们的代码.比如当我们能用 ...
- java学习进制转换之查表法
10进制转16进制,以及10进制转2进制,还有10进制转8进制,这些转换如果按照常规思路的话,会灰常的麻烦. 我们来看一下 10进制转16进制: 假如这里有一个十进制数字:35,我们的需求就是把这个3 ...
- 十进制和n进制的转换(10进制转换为36进制)
答案如下: void Convert() { map<int ,string> maps; maps[0]="0"; maps[1]="1"; ma ...
- lua之m进制转换为n进制-任意进制转换算法
够无聊的写这个,为防止需要的人也无聊一遍,写个吧 算法有n种,但是,咱们一种就够用了 --数组倒序排列 local function orderByDesc( input ) local output ...
- Java查表法实现十进制转化成其它进制
首先了解十进制转化成二级制的原理 156的二进制为: 156 % 2 = 78 …… 0 83 % 2 = 39 …… 0 39 % 2 = 19 …… 1 19 % 2 = 9 …… 1 9 % 2 ...
- YUV420查表法高效、无失真的转换为RGB32格式
YUV格式有两大类:planar和packed.planar的YUV格式,先连续存储所有像素点的Y,紧接着存储所有像素点的U,随后是所有像素点的V,这里所讲述的就是这中存储格式的:packed的YUV ...
随机推荐
- HTML中为何P标签内不可包含块元素?
起因:在做项目时发现原本在DW中无误的代码到了MyEclipse6.0里面却提示N多错误,甚是诧异.于是究其原因,发现块级元素P内是不能嵌套DIV的. 深究:我们先来认识in-line内联元素和blo ...
- NOJ 1641 错误的算法(模拟)
[1641] 错误的算法 时间限制: 5000 ms 内存限制: 65535 K 问题描述 有道题目是这样的: 输入一个 n 行 m 列网格,找一个格子,使得它所在的行和列中所有格子的数之和最大.如果 ...
- 使用CodeIgniter框架搭建RESTful API服务
使用CodeIgniter框架搭建RESTful API服务 发表于 2014-07-12 | 分类于 翻译笔记 | 6条评论 在2011年8月的时候,我写了一篇博客<使用Cod ...
- PHP IDE phpstorm 常用快捷键
PHP IDE phpstorm 常用快捷键 投稿:junjie 字体:[增加 减小] 类型:转载 这篇文章主要介绍了PHP IDE phpstorm 常用快捷键,本文分别列出了mac系统和Win ...
- file_get_contents无法获取数据的一种情况
下面这段php代码突然不好使了,返回的 $html 为空,百思不得解.网上说法好多,但都是一家之言,解决不了我的问题.(我的解决方法也是一家之言,只能解决file_get_contents获取不到数据 ...
- vector 初始化所有方法
简介:vector可用于代替C中的数组,或者MFC中的CArray,从许多说明文档或者网上评论,一般一致认为应该多用vector,因为它的效率更高,而且具备很好的异常安全性.而且vector是STL推 ...
- 捕获JS 错误日志
最近在做项目的过程中,发现很多JS报错没有引起重视,我就想想把JS错误捕获了,然后展示在我们一个平台上 具体实现代码: window.onerror = function(message, url, ...
- CC254x(cc2540/cc2541)的微信AirSync调试笔记
一.前言 本尊自诩为IOT小能手,一直没涉足蓝牙实在说不过去.刚好上个月底的时候计划做个BLE设备,这阵子利用业余时间自学了BLE协议栈,了解了GATT,磕磕绊绊完成CC254x(cc2540/cc2 ...
- hive中的常用方法(case,cast,unix_timestamp)
1.case的用法 )格式1 case col when value then '' when value then '' else '' end )格式2 case when col='value' ...
- Github简明教程(转)
原文地址 : http://wuyuans.com/2012/05/github-simple-tutorial/ github是一个基于git的代码托管平台,付费用户可以建私人仓库,我们一般的免费用 ...