C语言,求一个十进制数的二进制中1出现的次数,版本2.0(另外两种方法介绍)

十进制的数字要分离十进制的每一位,要先模上10,获取个位数,接着除以十,将每一个位数都降低一级。再模上十,获取下一位数上的数字,再模上10......以此类推。

而二进制要获得每一位数,也是一样的。先模上2,获取第一位数,接着除以2,将位数降低。接着再模2,再除2......直到全部转化为二进制。

cpp 复制代码
#include <stdio.h>
int fun(int n)
{
	int count = 0;
	while (n)
	{
		if (n % 2 == 1)
		{
			count++;
		}
		n /= 2;
	}
	return count;
}
//这种方法不适用于负数
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = fun(n);
	printf("%d", count);
	return 0;
}

每一次循环判断到求得的相应位数为1(即n % 2 为1)时,count就会加一。

但是这种方法有一个缺点,如果n为负数,count的值就会为零,因为count在count++之后就会变成0,而0进入到循环的判断条件中,就会终止循环。

-1的补码应该是32个一,结果应该为32。

正确做法是将函数接收到的参数n转化为无符号整型,如此-1就不会因为二进制的第一位被函数解读为负数了。

如图:

cpp 复制代码
#include <stdio.h>
int fun(unsigned int n)
{
	int count = 0;
	while (n)
	{
		if (n % 2 == 1)
		{
			count++;
		}
		n /= 2;
	}
	return count;
}
//这种方法不适用于负数
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = fun(n);
	printf("%d", count);
	return 0;
}

用按位与&实现的方法在我之前的博客中写过了,但是无论是按位与的方法还是上面的方法,当n够大的时候,都要进行多次计算。

有没有一种方法能有多少个一就计算多少次呢,这种方法比较难想到,但是代码本身比较简单。

cpp 复制代码
#include <stdio.h>
int fun(int n)
{
	int count = 0;
	while (n)
	{
		n = n & (n - 1);
		count++;
	}

	//101011
	//101010
	//按位与 第一次
	//101010
	//101001
	//按位与 第二次
	//101000
	//100111
	//按位与 第三次
	//100000
	//000001
	//按位与 第四次
	//000000

	//结果为四
	return count;
}
int main()
{
	int n = 0;
	scanf("%d", &n);
	int count = fun(n);
	printf("%d", count);
	return 0;

这里利用里二进制逢二进一的特点,每当一位数是1后面位数都是0时,减去一就是让其位数变成0。再利用按位与的特点,只有位数都为一时,结果位数才为1。

相关推荐
2601_949146533 小时前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
学嵌入式的小杨同学4 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
Aaron15884 小时前
基于RFSOC的数字射频存储技术应用分析
c语言·人工智能·驱动开发·算法·fpga开发·硬件工程·信号处理
爱编码的小八嘎5 小时前
C语言对话-21.模板特化,缺省参数和其他一些有趣的事情
c语言
yueyuexiaokeai17 小时前
linux kernel常用函数整理
linux·c语言
想放学的刺客8 小时前
单片机嵌入式试题(第29期)嵌入式系统的电源完整性设计与去耦电容选型。抗干扰设计与EMC合规性
c语言·stm32·嵌入式硬件·物联网·51单片机
集芯微电科技有限公司10 小时前
15V/2A同步开关型降压单节/双节锂电池充电管理IC支持输入适配器 DPM 功能
c语言·开发语言·stm32·单片机·嵌入式硬件·电脑
zz345729811313 小时前
c语言基础概念9
c语言·开发语言
v_for_van14 小时前
力扣刷题记录4(无算法背景,纯C语言)
c语言·算法·leetcode
启友玩AI14 小时前
方言守护者:基于启英泰伦CI-F162GS02J芯片的“能听懂乡音”的智能夜灯DIY全攻略
c语言·人工智能·嵌入式硬件·ai·语音识别·pcb工艺