20135327 郭皓 20135329 李海空小组作业2.69
2.69 写出具有如下原型的函数的代码
/*
*Do rotating right shitf. Assume 0 <= n < w
*Examples when x = 0x12345678 and w = 32:
* n = 4 -> 0x81234567 ,n = 20 -> 0x45678123
*/
unsigned rotate_right(unsigned x, int n);
答:本题主要是编写一个循环右移的函数,具体代码如下所示:
#include <stdio.h>
unsigned rotate_right(unsigned x, int n)
{
unsigned a;
a = x<<(32-n);
printf("%x\n",x>>n|a);
}
int main()
{
unsigned x;
int n;
printf("请输入32位十六进制数");
scanf("%x",&x);
printf("请输入右移位数(小于32大于等于0)");
scanf("%d",&n);
if(n>32||n<=0)
{
printf("右移位数小于32大于等于0!!!");
return 0;
}
rotate_right(x,n);
return 0;
}
这里我默认w=32 因为要是32位以内的十六进制数必须更改w的取值否则系统默认为32位十六进制,如需修改只需将32改为w即可。
下图为测试结果:
试试其他数: