输出整数的二进制表示 C语言

本文介绍了一个简单的C语言程序,用于输出一个整数在指定范围内的二进制位。程序接收用户输入的一个整数及两个位置参数,然后输出该整数在从右端开始的这两个位置之间的二进制位。

题目:输入一个整数a,再输入两个整数p1,p2(p1,p2<32),输出该整数的二进制表示方法中从右端开始的p1到p2位.

题中处理的是int型变量

从右端开始,输出p1(>=0)位到p2位(<=31)的二进制位

具体的解释已在代码注释中,不懂可以评论区留言,看到后会及时回复

#include <stdio.h>
#include <stdlib.h>
void b_number(int n, int r_start, int r_end);  //二进制位打印函数
int main()
{
        int n;
        int r_start, r_end;   //开始位,结束位
        printf("从右往左输出输入的数的二进制位\n");
        printf("start and end from 0 to 31\n");
        printf("Please input three numbers as a space separated.\n");
        printf("输入的数    起始位(右) 结束位(右)\n");

        scanf("%d %d %d", &n, &r_start, &r_end);
	if (r_start < 0 || r_end > 31)   //判断,若输入的开始位结束位值不符合要求,则直接退出程序
	{
		fprintf(stderr, "输入的数有误!\n");
		exit(EXIT_FAILURE);
	}
        printf("%d = 0b", n);
        b_number(n, r_start, r_end);
        return 0;
}
void b_number(int n, int r_start, int r_end)
{
        int flag = 1;   //flag赋值1
        int i;    //循环次数
        for (i = r_end; i >= r_start; i--)  //从高位开始(p2位)开始输出
        {
                flag = flag << i;    //flag最低位的1移位到相应的位置
                if (flag & n)   //通过与运算判断是否为1,并输出结果
                        printf("1");
                else
                        printf("0");
                flag = 1;
        }
        printf("\n");
}

### C语言输出整数二进制形式 在C语言中,虽然没有内置的方式直接以二进制形式打印整数,但可以通过手动操作位的方式来实现这一功能。以下是几种常见的方法: #### 方法一:循环逐位输出 这种方法通过不断右移整数提取最低有效位来构建二进制表示。 ```c #include <stdio.h> void printBinary(int num) { for (int i = 31; i >= 0; i--) { // 假设为32位整数 printf("%d", (num >> i) & 1); // 提取第i位的值 } printf("\n"); } int main() { int number; printf("输入一个整数: "); scanf("%d", &number); printBinary(number); return 0; } ``` 这段代码会从最高位到最低位依次输出给定整数的每一位二进制值[^3]。 --- #### 方法二:递归法 递归方法是从低位向高位逐步输出每位二进制值。这种方式更简洁易懂。 ```c #include <stdio.h> void to_binary(unsigned int n) { if (n / 2 != 0) { // 当商不为零时继续调用自身 to_binary(n / 2); } putchar('0' + n % 2); // 输出余数部分 } int main() { unsigned int number; printf("输入一个无符号整数: "); scanf("%u", &number); to_binary(number); putchar('\n'); return 0; } ``` 此版本采用除基取余的思想,借助递归来反转顺序从而得到正确的二进制表达[^2]。 --- #### 方法三:使用数组存储结果后再倒序打印 这是一种更为通用的做法,尤其适合需要进一步处理二进制字符串的情况。 ```c #include <stdio.h> #include <string.h> char *toBinaryString(char str[], size_t len, unsigned int num) { memset(str, '0', len - 1); // 初始化字符数组全为‘0’ str[len - 1] = '\0'; // 设置字符串结束符 int index = len - 2; do { str[index--] = '0' + (num & 1); // 添加当前位至适当位置 num >>= 1; // 右移一位准备下一轮计算 } while(num && index >= 0); return str + ((index + 1) > 0 ? (index + 1) : 0); // 返回指向第一个非前导零处的指针 } int main() { char buffer[33]; // 考虑到最多有32个bit加上终止符'\0' unsigned int number; printf("输入一个无符号整数: "); scanf("%u", &number); puts(toBinaryString(buffer, sizeof(buffer), number)); return 0; } ``` 这个方案允许灵活控制输出长度以及便于后续加工处理所得的二进制串[^4]。 --- #### 性能与适用场景分析 - 对于简单的调试用途,推荐使用**方法一或方法二**,它们简单直观且易于理解。 - 如果涉及复杂的业务逻辑或者需要保存中间状态,则建议选用**方法三**,因为它提供了更大的灵活性和可扩展性。 以上三种方式均能满足基本需求,在具体项目开发过程中可根据实际情况选取最合适的解决方案。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值