[英]C++ Left Shift Operation Bit Manipulation
我不明白為什么它在某個點后給出負數。 我也使用 long long 來防止溢出。
代碼
#include <iostream>
using namespace std;
int main() {
for(long long i=0;i<64;i++){
cout << 1LL*(1<<i) << " ";
}
return 0;
}
Output
1 2 4 8 16 32 64 128 256 512 1024 2048 4096 8192 16384 32768 65536 131072 262144 524288 1048576 2097152 4194304 8388608 16777216 33554432 67108864 134217728 268435456 536870912 1073741824 -2147483648 1 2 4 8 16 32 64 128 256 512 1024 2048 4096 8192 16384 32768 65536 131072 262144 524288 1048576 2097152 4194304 8388608 16777216 33554432 67108864 134217728 268435456 536870912 1073741824 -2147483648
1 << i
..在上面的行中, 1
是一個int
而 i 是一個long long
。 因此,要解決您的問題,您可以long long
使用:
#include <iostream>
using namespace std;
int main() {
for (long long i = 0; i < 64; i++) {
cout << 1LL * (static_cast<long long>(1) << i) << " ";
}
return 0;
}
這將允許您將 go 設置為更高的值。
您還可以使用1LL
( 1 long long
) 而不是強制轉換:
cout << 1LL * (1LL << i) << " ";
..有了這個你可以刪除1LL *
:
cout << (1LL << i) << " "; // Brakcets are required
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.