判断一个数是否是2的幂(1,2,4,8,16,........)

#include<stdio.h>
#include<stdbool.h>
bool ispower(int n)
{
	//while (n % 2 == 0)//(n&0x1==0)
	//{
	//	n = n / 2;//n>>1;右移相当于除以2的n次方
	//}
	//return n == 1;
	return (n & n - 1) == 0;//2的幂的二进制数只有一个1
	//n:   0100 0000         0101 0000
	//n-1: 0011 1111         0100 1111
}
int main(void)
{
	int i = 0;
	scanf("%d", &i);
	ispower(i);
	printf("%s\n", ispower(i) ? "true" : "false");
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值