写一个宏, 将一个32位的数的第m位和第n位互换位置
#define t(val, m, n) ((((val) & (1<<(m))>>(m))<<(n))|((((val) & (1<<(n))>>(n))<<(m)) | ((val) & ~(1<<(m)|1<<(n)))
#define t(val, m, n) ()|( | )
(val) & (1<<(m)) //取出第m位
(>>(m)) //放回第一位
(<<(n) //放置到第n位
(val) & (1<<(n)) //取出第n位
(>>(n)) //放回第一位
(<<(m)) //放置到第m位
(val) & ~(1<<(m)|1<<(n)) //恢复其他位
阅读(904) | 评论(0) | 转发(0) |