欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

重写的标题:在C语言中实现数字和字符串的循环位移操作

最编程 2024-08-11 22:04:18
...
C语言中没有提供循环移位的操作符,但可以通过简洁的方式实现循环移位
设一个操作数x有s位则循环左移n位的操作为:
(x << n) | (x >> (s - n));
同理右移n位位:
(x >> n) | (x << (s - n));
实际编程中可以用宏定义实现循环移位:
#define ROTATE_LEFT(x, s, n) ((x) << (n)) | ((x) >> ((s) - (n)))
#define ROTATE_RIGHT(x, s, n) ((x) >> (n)) | ((x) << ((s) - (n)))

例如:
#include <stdio.h>
#define ROTATE_LEFT(x, s, n) ((x) << (n)) | ((x) >> ((s) - (n)))
#define ROTATE_RIGHT(x, s, n) ((x) >> (n)) | ((x) << ((s) - (n)))
int main()
{
unsigned int a;
scanf("%x", &a);
printf("%08x\n", a);
printf("%08x\n", ROTATE_LEFT(a, 8 * sizeof(int), 4));
printf("%08x\n", ROTATE_RIGHT(a, 8 * sizeof(int), 8));
return 0;
}

运行结果:

12345678 //原数

23456781 //移1位后

具体样例:

设有数据a=01111011,循环左移2位 正确结果: 11101101

 分步实现:

b=a>>(8-2) ;//用来得到正常左移丢失的位和循环移位后其正确位置 b="00000001";

a="a"<<2;//左移 a="11101100"

a=a|b; //a=11101101

 如果不是用中间变量一步实现: a=(a>>(8-2))|(a<<2);

 总长度N(8 16 32)

 循环左移n (a>>(N-n))|(a>>n)

 循环右移n (a<<(N-n))|(a>>n)

 C语言的位运算功能是其区别于其他大多数高级程序设计语言的特色之一,用它可以方便实现一些特殊功能,灵活掌握是用C程序编写系统程序的基础。

其他对位进行操作的还有位域法;

几个对位操作的样例如下:

#define SETBIT(REG,N) REG|=(1<<

推荐阅读