编写一个函数,实现左右循环移位。函数名为move,调用方法为move(value, n)。其中value为需要循环位移的数,n为位移的位数。n<0表示为左移;n>0表示为右移。例如,n=4表示右移4位;n=-3表示左移3位。
请务必注意本题中的整数是32位无符号整数,输入和输出时可以使用%u进行处理。
样例输入
128 -3样例输出
1024
注意:该题是循环位运算
AC代码
#include<iostream>
#include<vector>
#include<algorithm>
#include<iomanip>
using namespace std;
int main()
{
unsigned int value,v1,v2;
int n;
cin >> value >> n;
if (n < 0)
{
v1 = value << abs(n);
v2 = value >> 32 - abs(n);
}
else
{
v1 = value >> n;
v2 = value << 32 - abs(n);
}
cout <<v1+v2 << endl;
}