码迷,mamicode.com
首页 > 其他好文 > 详细

9.5位操作(六)——交换某个整数的奇数位和偶数位,使用指令越少越好

时间:2015-08-06 15:09:04      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:java   数据结构   算法   位操作   二进制   

/**
 * 功能:交换某个整数的奇数位和偶数位,使用指令越少越好(即,位0与位1交换,位2与位3交换,以此列推)。
 */

	/**
	 * 思路:先操作奇数位,再操作偶数位。将数字n的奇数位右移1位,偶数位左移1位。
	 * @param x
	 * @return
	 */
	public static int swapOddEvenBits(int x){
		//奇数位右移,0xaaaa aaaa=10101010 10101010 10101010 10101010 10101010 10101010 10101010 10101010b;
		int odd=(x&0xaaaaaaaa)>>1;
		
		//偶数位左移,0x5555 5555=01010101 01010101 01010101 01010101 01010101 01010101 01010101 01010101b;
		int even=(x&0x55555555)<<1;
		
		return odd|even;
	}


版权声明:本文为博主原创文章,未经博主允许不得转载。

9.5位操作(六)——交换某个整数的奇数位和偶数位,使用指令越少越好

标签:java   数据结构   算法   位操作   二进制   

原文地址:http://blog.csdn.net/shangqing1123/article/details/47316101

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!