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即可。

下图为测试结果:

试试其他数:

 

posted @ 2015-10-20 14:15  20135327郭皓  阅读(152)  评论(0编辑  收藏  举报