我是靠谱客的博主 优雅路灯,最近开发中收集的这篇文章主要介绍C 寻找一个字节的整数中1的个数,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

题目:查找1个字节的整数中1的个数

思路:将整数转化为二进制形式,利用按位与判断每位是否为1

程序如下:

#include<stdio.h>       
int bitnum(int num);/*计算1的位数的函数*/
void bitout(int num);/*输出二进制形式的函数*/
int  main()
{
int  num;
printf("enter num(0 to 255):");
scanf("%d", &num);
/*限制一个字节*/
if( num >= 0&& num<= 255)
{
bitout(num);
printf("n置1的位数是%dn", bitnum(num));
}
else
printf("error!n");
return 0;
}
int bitnum(int num)
{
int i;
int temp = 0;
for( i = 0; i < 8; i++)
{
/*按位与判断是否为1*/
if((num>>i)&1)
{
temp++;
}
}
return temp;
}
void bitout(int num)
{
int i;
for( i = 7; i >= 0; i--)
{
putchar((num&1<<i)?'1':'0');
}
}

结果:

enter num(0 to 255):213
11010101
置1的位数是5

最后

以上就是优雅路灯为你收集整理的C 寻找一个字节的整数中1的个数的全部内容,希望文章能够帮你解决C 寻找一个字节的整数中1的个数所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部