C++算法之 一句话推断一个整数是不是2 的整数次方
Posted wzjhoutai
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++算法之 一句话推断一个整数是不是2 的整数次方相关的知识,希望对你有一定的参考价值。
思路:一个整数假设是2的整数次方,那么它的二进制表示中有且仅仅有一位是1,而其它全部位都是0。把这个整数与这个整数减去1之后进行与运算。那么这个整数其中唯一的
1会变为0,这个整数也变为0;
代码:
// Is2.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include <iostream> using namespace std; bool is2(int n) { return !( n&(n-1)); } int _tmain(int argc, _TCHAR* argv[]) { bool b = is2(2); cout<<b<<endl; bool c = is2(3); cout<<c<<endl; getchar(); return 0; }
以上是关于C++算法之 一句话推断一个整数是不是2 的整数次方的主要内容,如果未能解决你的问题,请参考以下文章
500,000 个已排序整数数组上的 C++ 快速排序算法中的 Seg 错误