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 ...
随机推荐
- sizeToFit()使用心得
sizeToFit()使用心得: 很多的初学者,包括我在内,当初在学习的时候,特别纠结什么时候用这个sizeToFit(). 下面我就来分享一下我的一些使用心得. 一.我们先来看看官方文档对sizeT ...
- iOS开发项目之二 [ App appicon与启动图]
*appicon尺寸 *不是所有的appicon都是需要配置 *尽量不要透明--(透明的话,会在桌面显示成背景黑色) 1 如果没有配置5s的启动图,回去往下找,找到4s之后,会把界面以4s启动图的大小 ...
- ITK 4.8.1 Qt 5.4 MinGW 4.9.1 Configuration 配置
Download ITK 4.8.1 Download Qt 5.4 with MinGW 4.9.1 Download CMake 3.2.0 I assume you've already ins ...
- spark Mllib SVM实例
Mllib SVM实例 1.数据 数据格式为:标签, 特征1 特征2 特征3…… 0 128:51 129:159 130:253 131:159 132:50 155:48 156:238 157: ...
- JavaScript系列:模块化与链式编程
模块化:闭包和和函数作用域(JS没有块级作用域ES6之前)构造模块 var man=function(){ var age=12; return { getYear:function(){ retur ...
- [kuangbin带你飞]专题六 最小生成树
学习最小生成树已经有一段时间了 做一些比较简单的题还算得心应手..花了三天的时间做完了kuangbin的专题 写一个题解出来记录一下(虽然几乎都是模板题) 做完的感想:有很多地方都要注意 n == 1 ...
- maven资源文件的相关配置
构建Maven项目的时候,如果没有进行特殊的配置,Maven会按照标准的目录结构查找和处理各种类型文件. src/main/java和src/test/java 这两个目录中的所有*.java文件会 ...
- Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.5:compile
mvn clean mvn install mvn clean -Dmaven.test.skip=true install 出现上述问题,找不到很多类的一些方法. 解决方法: 1.Window -- ...
- thread、operation、GCD
// ViewController.m #import "ViewController.h" @interface ViewController () { //任务队列,能够自动管 ...
- select * 所有字段时如何巧妙的使用覆盖索引
内容从"mysql高性能书籍" 179页摘取 当select * 时.往往使用不到索引..效率不高,因为查询从表中选择所有的列,没有任何索引能覆盖所有的列.不过还是有捷径可以利用 ...