国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

不用加減乘除做加法

2019-11-08 03:19:15
字體:
來源:轉載
供稿:網友

題目描述

寫一個函數,求兩個整數之和,要求在函數體內不得使用+、-、*、/四則運算符號。

算法描述:

如果我們將兩個整數相加看作兩步位運算即可,舉個栗子,19 + 31,二進制為0001_0011 + 0001_1111, 我們先不考慮進位的加法,其實在位運算上和異或相同,則sum = 0001_0011 ^ 0001_1111 = 0000_1100,同時計算進位carry = 0001_0011 & 0001_1111 << 1 = 0010_0110,第二步就將sum 和 carry進行加法操作,直到最后沒有進位的時候,加法完成。

代碼如下:

public int Add(int num1, int num2) { int sum, carry; do { sum = num1 ^ num2; carry = (num1 & num2) << 1; num1 = sum; num2 = carry; } while (num2 != 0); return num1; }
上一篇:C#的chart圖形

下一篇:深入淺出CUDA編程

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 三河市| 安陆市| 曲松县| 绥阳县| 栖霞市| 琼结县| 邓州市| 满洲里市| 金寨县| 富平县| 夏河县| 马山县| 锦州市| 抚顺市| 辽源市| 兰考县| 钟山县| 商城县| 武定县| 和平区| 卢龙县| 丹阳市| 滦平县| 保山市| 科尔| 韶关市| 三门峡市| 太湖县| 陵川县| 沙坪坝区| 临沭县| 读书| 黎川县| 淮北市| 华宁县| 名山县| 万宁市| 鞍山市| 宝兴县| 文成县| 酉阳|