输出整数n的二进制形式

输出整数n的二进制形式:

如:

0 输出 0

1 输出 1

2 输出 10

10 输出 1010


数组方式:

void print_binary(int n)
{
	char arr[32] = {0};
	int len = 0;
	do 
	{
		arr[len++] = (n&1)+'0', n = n>>1;
	} while (n);
	while (len-- > 0 && printf("%c", arr[len]));
	printf("\n");
}

不用数组:

void print_binary(int n)
{
	// int类型4个Byte, 共32位
	int max_len = 32;
	// 寻找第一次出现1的位置
	while (max_len-- > 0 && !(n>>max_len));
	// 如果找不到1(如n为0时), 修改max_len为1
	if (++max_len == 0) max_len = 1;
	// 从第一次出现1的位置开始输出
	while (max_len-- > 0 && printf("%d", (n>>max_len)&1));
	printf("\n");
}

测试用例:

print_binary(-2);
print_binary(-1);
print_binary(0);
print_binary(1);
print_binary(2);
print_binary(10);
print_binary(15);
print_binary(100);
print_binary(1000);

输出:

11111111111111111111111111111110
11111111111111111111111111111111
0
1
10
1010
1111
1100100
1111101000


### 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]。 --- #### 性能与适用场景分析 - 对于简单的调试用途,推荐使用**方法一或方法二**,它们简单直观且易于理解。 - 如果涉及复杂的业务逻辑或者需要保存中间状态,则建议选用**方法三**,因为它提供了更大的灵活性和可扩展性。 以上三种方式均能满足基本需,在具体项目开发过程中可根据实际情况选取最合适的解决方案。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值