C语言格式输出二进制的2种方法总结

目录
  • 1.前言
  • 2.源码实现
  • 3.结果展示
  • 附:C语言如何将一个数字的二进制形式输出出来
  • 总结

1.前言

在我们日常的编程中,有时候需要格式化输出一个整形数据的二进制,但是在我们C语言中只有

  • 输出十进制:%d
  • 输出十六进制:%x
  • 输出单个字符:%c
  • 输出字符串:%s
  • 输出变量所在的地址:%p

而并没有这种二进制对应的格式,所以需要我们手动来实现。

2.源码实现

本篇博客给大家介绍两种方法:

1.通过库函数itoa,需要包含头文件:#include <stdlib.h>;

2.通过十进制转成二进制的常用方法——短除法;

为方便大家使用,将两种方法都封装成了函数,源码如下:

#include <stdio.h>
#include <stdlib.h>

#define uint32 unsigned int
#define uint8 unsigned char

void FuncOutputBin(uint32 value)
{
	char string[33];   //形参类型uint32最大为32位,因此我这里定义了大小为33的字符串数组存放
	itoa(value, string, 2);
	printf("库函数得到的二进制为:%s\r\n",string);
}

//用短除法的思想得到二进制,之后将数据从后往前读取
void ShortDivOutputBin(uint32 input)
{
	uint8 temp[33] = {0};
	int i = 0;
	printf("短除法得到的二进制为:");
	while(input)
	{
		temp[i] = input % 2;	//取余数存放到数组中,此为得到的二进制数
		input = (uint32)input / 2;  //短除,while中判断是否除尽
		i++;  //存储了一个二进制数,自加存储下一个
	}
	for(i--; i>=0; i--)  //由于最后一次input为0无效,i还是自加了,因此最后一次自加的值是无用的,所以先自减,然后将余数从后往前读取
    {
		printf("%d",temp[i]);
	}
	printf("\r\n");
}

void main(void)
{
	uint32 input = 0;
	printf("请输入一个需要转化为2进制的整形数据:");
	scanf("%d", &input);
	FuncOutputBin(input);
	ShortDivOutputBin(input);
}

itoa函数原型:char *itoa( int value, char *string,int radix)
功能:将整形数据value转化成需要的进制radix,然后将之以字符串的形式存放在string中;
返回值:转化成对应进制后的字符串的地址,也可以不使用返回值;
它的三个参数依次为:
value:需要转化的整形数据;
string:转化成对应进制后的字符串的地址;
radix :需要转化的进制(我这里需要转化为2进制,所以填2);

3.结果展示

(有图有真相咯~)

附:C语言如何将一个数字的二进制形式输出出来

一. 我们知道由十进制转二进制的算法,因此可以直接计算出其二进制数

例如:对3求其二进制

int main()
{
	int n = 3;
	int arr[33] = { 0 };//int 型有32个字节
	int i = 0;
	while (n > 0)
	{
		arr[i] = n % 2;
		++i;
		n /= 2;
	}
	int k = 0;
	for (k = i-1; k >= 0; k--) //逆序输出
	{
		printf("%d", arr[k]);
	}
	return 0;
}

二. 因为数字在计算机中就是以二进制的形式存储的,那我们也可以通过  位运算符  来表示出一个数的二进制。

用&(按位与)运算符,其运算原理是对其两个操作数的计算机内存储的二进制形式(补码)的对应位进行按位与,如果1&1结果是1,其他结果都是0。

例如 3&5:

int a = 3;
//a: 00000000000000000000000000000011

int b = 5;
//b: 00000000000000000000000000000101

int c = a & b;
//c: 00000000000000000000000000000001

因此,可以让一个数n&1,然后得到n的二进制的第一位的值(如果结果是1,那n的二进制的第一位也是1,如果是0,那第一位是0),然后让n右移一位n>>1,然后找其第二位。。。。。。然后一直遍历到第32位。

int main()
{
	int n = 5;
	int i = 0;
	int arr[33] = { 0 };//int 是有32位的
	//从第一位开始依次取n对应二进制的每一位
	for (i = 1; i <=sizeof(int) * 8; i++)
	{
		arr[i] = n & 1;
		n=n	>> 1;
	}
	//printf("%d\n", i);
	int k = 0;
	//逆序输出
	for (k = i-1; k >= 1; k--)
	{
		printf("%d", arr[k]);
	}

	printf("\n");
	return 0;
}

运算结果:

但是用数组存,有点麻烦,所以我又改进了一下

int main()
{
	int n = 5;//0000000101
	int i = 0;
	int k = 1 << 31;

	for (i = 0; i < sizeof(int) * 8; i++)
	{
		printf("%d", -((n & k) >> 31));
		n <<= 1;
	}

	printf("\n");
	return 0;
}

但是我感觉还是有点麻烦,可又想不出更好的方案了。。。。。。

总结

到此这篇关于C语言格式输出二进制的2种方法的文章就介绍到这了,更多相关C语言格式输出二进制内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C语言实现文本文件/二进制文件格式互换

    本程序要自己创建个文本格式的输入文件a1.txt,编译后能将文本文件前255字节以内的字符转换成相应的AscII码值的二进制表示,并存入输出文件a2.txt中.然后再将二进制文件还原并存入a3.txt文件. 具体代码如下: #include <cstdio> #include <stdio.h> #include <string.h> #define NSIZE 8 void print_2(int val2); /***********文本文件转二进制********

  • c语言二进制数按位输出示例

    提出问题: 1.输入int 20,其二进制为10100,按位输出10100; 2.或者将1转化为"+",0转化为"-",输出就是" + - + - - "; 解决方法: 复制代码 代码如下: int biTofh(int bi,int len){//二进制转化为正负号        int i=0;        while(i<len){                int tmp = 1;                if((bi

  • C语言格式输出二进制的2种方法总结

    目录 1.前言 2.源码实现 3.结果展示 附:C语言如何将一个数字的二进制形式输出出来 总结 1.前言 在我们日常的编程中,有时候需要格式化输出一个整形数据的二进制,但是在我们C语言中只有 输出十进制:%d: 输出十六进制:%x: 输出单个字符:%c: 输出字符串:%s: 输出变量所在的地址:%p: 而并没有这种二进制对应的格式,所以需要我们手动来实现. 2.源码实现 本篇博客给大家介绍两种方法: 1.通过库函数itoa,需要包含头文件:#include <stdlib.h>: 2.通过十进

  • php格式文件打开的四种方法

    php文件格式怎么打开?要搞清楚php文件用什么打开,首先我们来看php文件是什么文件,PHP是一个网页脚本,文件后缀名为.php,如下图: 但不同于html xml 标签语言,直接可以通过浏览器打开,php文件需要有PHP的运行环境才可以访问和打开,如果只是编辑PHP文件,只需要用: php文件打开方式一:用记事本打开 右击.php文件,选择记事本打开,就可以看到文件代码啦! php文件打开方式二:用Dreamweaver打开 Dreamweaver是网页编辑器,比较流行的网站开发工具,你可以

  • C语言实现倒置字符串的两种方法分享

    目录 前言 一.题目 二.思路讲解 三.代码实现 四.代码总结 五.第二种方法倒置字符串 六.总结 前言 今天在牛客网上刷了一道题,我感觉挺有意义的,现在我就分享给大家,并且告诉大家解题思路. 一.题目 事例: 输入下列字符: I like beijing. 输出的字符: beijing. like I 二.思路讲解 1.设立一个数组存放输入的字符串 2.将其中每个单词进行逆置 得到 I ekil .gnjieb 3.再将字符串逆置  得到beijing.like I 三.代码实现 1.设立一个

  • Python格式化输出字符串的五种方法总结

    目录 1. 引言 2. 函数 center() 3. 函数 ljust() 4. 函数 rjust() 5. 函数 zfill() 6. 函数 title() 7. 使用 1. 引言 Python语言有许多优点,常用于不同的领域,如数据科学.web开发.自动化运维等.开发人员在这些技术中选择Python的一个重要原因是Python语法简单,可以节省大家的开发时间. 在本文中,我们将学习如何使用字符串中内置的方法来格式化字符串.闲话少说,我们直接开始吧! 2. 函数 center() 函数cent

  • R语言将变量分组的3种方法实例(含cut函数说明)

    目录 前言 方法一:直接对分组变量进行赋值 方法二:使用within函数对变量进行分组 方法三:采用cut函数 总结 前言 在数据处理的过程中,我们有时候需要将连续的数值数据转换为类别数据,比如将收入分成高.中和低三组,将学生成绩分为优.良.中.及格和不及格五组. 本来将基于R语言,采用三种方法来实现:第一种是对变量直接进行重新赋值,第二种是使用within函数对语句进行组织,第三种是cut函数. 首先我们定义一个数据框,这个数据框包括学生姓名和数学成绩两个变量. #定义数据框 mathScor

  • JS扁平化输出数组的2种方法解析

    这篇文章主要介绍了JS扁平化输出数组的2种方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.使用数组的flat方法 [1,2,[3,[4,5]]].flat(Infinity) //[1, 2, 3, 4, 5] 2.实现方式二: var arr = [[1, 2, 23], [13, 4, 5, 5], [6, 7, 9, [11, 12, [12, 13, [14]]]], 10]; var result = []; functi

  • C语言实现求解素数的N种方法总结

    目录 前言 必备小知识 C语言详解<试除法>求解素数 试除法境界1 试除法境界2 试除法境界3 试除法境界4 C语言详解<筛选法>求解素数 筛选法境界5 前言 哈喽各位友友们,我今天又学到了很多有趣的知识,现在迫不及待的想和大家分享一下!我仅已此文,手把手带领大家探讨利用试除法.筛选法求解素数的n层境界!都是精华内容,可不要错过哟!!! 必备小知识 质数又称素数.一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数:否则称为合数(规定1既不是质数也不是合数).这里

  • Go语言拼接URL路径的三种方法

    目录 JoinPath ResolveReference path.Join 参考 Go语言拼接URL路径有多种方法建议用ResolveReference. JoinPath JoinPath会把多个多个路径合并成一个路径,并且处理../和./,多个//合并成单个/. package main import (     "fmt"     "net/url" ) func main() {     u1 := "http://example.com/dir

  • R语言导入导出数据的几种方法汇总

    导出: 对于某一数据集导出文件的方法 导出例子:write.csv(data_1,file = "d:/1111111111.csv") 其中data_1是你的数据集,file是你的存储路径和要存储的名字 导入: 1  使用键盘输入数据 (1) 创建一个空数据框(或矩阵),其中变量名和变量的模式需与理想中的最终数据集一致: (2)针对这个数据对象调用文本编辑器,输入你的数据,并将结果保存回此数据对象中. 在下例中,你将创建一个名为mydata的数据框,它含有三个变量:age(数值型).

  • Go读取文件与写入文件的三种方法操作指南

    目录 文件写入操作 Write和WriteString写入操作 使用buffio内置包来读文件 第三种写入文件方法:ioutil.WriteFile 总结 打开和关闭文件操作: os.Open()函数能够打开一个文件,返回一个*File和一个err.对得到的文件实例调用close()方法能够关闭文件. package main import ( "fmt" "os" ) //文件操作 func main(){ //打开文件 file, err := os.Open(

随机推荐