91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中的異或問題代碼解析

發布時間:2020-10-25 10:47:04 來源:腳本之家 閱讀:121 作者:Islandww 欄目:編程語言

java的位運算符中有一個叫異或的運算符,用符號(^)表示,其運算規則是:兩個操作數的位中,相同則結果為0,不同則結果為1。下面看一個例子:

public class TestXOR{
	public static void main(String[] args){
		int i = 15, j = 2;
		System.out.println("i ^ j = " + (i ^ j));
	}
}

運行結果是:i^j=13.

分析上面程序,i=15轉成二進制是1111,j=2轉成二進制是0010,根據異或的運算規則得到的是1101,轉成十進制就是13.

利用這個規則我們可以靈活運用到某些算法。比如,假定有2K+1個數,其中有2k個相同,需要找出不相同的那個數,比如:2、3、4、4、3、5、6、6、5。我們利用異或運算符就可以這樣寫:

public class TestXOR{
	public static void main(String[] args){
		int[] array = {2,3,4,4,3,5,6,6,5};
		int v = 0;
		for (int i = 0;i < array.length;i++) {
			v ^= array[i];
		}
		System.out.println("只出現一次的數是:" + v);
	}
}

結果是:只出現一次的數是2.

我們就是巧用異或運算符的規則,得出一個數和0異或還是自己,一個數和自己異或是0的原理。

上述計算方式:v=2^3^4^4^3^5^6^6^5;

根據交換律以及上述規則

可以推出只出現一次的數(需滿足前提條件2k個相同)

總結

以上就是本文關于java中的異或問題代碼解析的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

侯马市| 六枝特区| 宁蒗| 文登市| 彭阳县| 城固县| 镇康县| 黄冈市| 绥棱县| 清水河县| 黑水县| 虞城县| 岫岩| 瑞昌市| 孟村| 高邮市| 凯里市| 淄博市| 红桥区| 宝山区| 睢宁县| 花垣县| 德阳市| 顺义区| 中超| 武安市| 栖霞市| 六枝特区| 府谷县| 泽普县| 琼海市| 曲靖市| 芜湖县| 瑞昌市| 徐水县| 资中县| 陆川县| 松溪县| 凉城县| 于田县| 年辖:市辖区|