真的没骗你,这道才是简单题 —— 对任意给定的不超过10的正整数n,要求你输出2n。不难吧?
输入格式:
输入在一行中给出一个不超过10的正整数n。
输出格式:
在一行中按照格式“2^n = 计算结果”输出2n的值。
输入样例:5输出样例:
2^5 = 32
脑补一下位运算,别人一行代码就出来的的题我还傻了吧唧的用打表还自以为很高效,时间的差距一下子就出来了,一定更快更广泛的了解更多的知识
#include <iostream>
using namespace std;
int main()
{
int n;
while(cin>>n)
{
long long s=1;
s<<=n;
cout<<"2^"<<n<<" = "<<s<<endl;
}
return 0;
}
位运算相关脑补
位运算是指按二进制进行的运算。在系统软件中,常常需要处理二进制位的问题。C语言提供了6个位操作运算符。这些运算符只能用于整型操作数,即只能用于带符号或无符号的char,short,int与long类型。
C语言提供的位运算符列表:
运算符含义描述
&
|
^
~
<<
>>
1、“按位与”运算符(&)
则该位的结果值为1;否则为0。这里的1可以理解为逻辑中的true,0可以理解为逻辑中的false。按位与其
实与逻辑上“与”的运算规则一致。逻辑上的“与”,要求运算数全真,结果才为真。若,
A=true,B=true,则A∩B=true
定,凡是非十进制的数据均在数据后面加上括号,括号中注明其进制,二进制则标记为2)内存储存数据
的基本单位是字节(Byte),一个字节由8个位(bit)所组成。位是用以描述电脑数据量的最小单位。二
进制系统中,每个0或1就是一个位。将11(2)补足成一个字节,则是00000011(2)。5的二进制编码是
101(2),将其补足成一个字节,则是00000101(2)
按位与运算:
&00000101(2)
由此可知3&5=1
c语言代码:
#include
main()
{