c語言位操作符相關題目之交換兩個數的值

文章目錄

  • 一、題目
  • 二、方法1
    • 1,思路
    • 2,代碼實現
  • 三、方法2
    • 1,思路
    • 2,代碼實現
  • 四、方法3
    • 1,思路
    • 2,代碼實現
  • 總結

提示:以下是本篇文章正文內容,下面案例可供參考

一、題目

實現兩個變量的交換

輸入:a = 5,b = 3;輸出 :a = 3 ,b = 5。

二、方法1

1,思路

這個方法就是我們經常遇到此問題想到的空瓶交換,額外創建一個變量開辟一份空間來暫時存儲變量。好比下方圖片,我有三個碗,一個碗里面放了醋,一個放了醬油,我想將放醬油的碗里面放上醋,放醋的碗里面放上醬油。于是我需要第三個碗,先將醬油放在空碗內,在將醋倒進醬油碗中,在將空碗里的醬油放在醋碗中。

在這里插入圖片描述

2,代碼實現

代碼如下(示例):

int main()
{int a = 5;int b = 3;int c = 0;printf("交換前:a = %d,b = %d\n", a, b);c = a;a = b;b = c;printf("交換后:a = %d,b = %d\n", a, b);return 0;
}

三、方法2

1,思路

這個是一個不創建中間變量的方法,但是此方法存在缺陷:如果a和b的很大,但是沒有超出整型的大小,a和b的值的和超出了整型的大小,超出整形大小的值之后,有些值就溢出了丟了,這樣和就不準確了,導致后面求出的值是錯誤的,所以這個方法交換得兩個數之和不大于整型變量的最小存儲值

  1. 先將a+b的值放在a中,此時a的值變成a+b
  2. 再將a-b的值放在b中,因為此時a變成了a+b,所以a-b的值等價于a+b-b=a,此時存放在b中的值變成a了。
  3. 最后一步將a-b的值放入a中,此時a的值還是a+b;b的值變成a了,所以a-b=b,此時存放在a中的值變成b了。
  4. 通過上面三步我們實現了a和b的交換。

2,代碼實現

代碼如下(示例):

int main() 
{int a = 5; int b = 3; printf("交換前:a = %d,b = %d\n", a, b); a = a + b; b = a - b; //此時b = a + b - b = a; a = a - b; //此時a = a + b - a = b; printf("交換后:a = %d,b = %d\n", a, b); return 0; 
}

四、方法3

1,思路

在這里我們采用的方法是c語言操作符的解法 ,在這里我們需要理解下面兩個c語言位操作符——按位異或的規律才可以得到正確的解法

  1. a ^ a = 0,按位異或的規則是按照二進制位進行按位異或,相同的位為0,不相同為1.兩個數都相同,相同所有位為0,所以所有數字都等于0
  2. a ^ 0 = a; 任何數與0異或都等于0,例如3^0 = 011^000 = 011 = 3;
  3. //a 0000 0000 0000 0000 0000 0000 0000 0101
    //b 0000 0000 0000 0000 0000 0000 0000 0011
    //^ 0000 0000 0000 0000 0000 0000 0000 0110 a = a^b
    //^ 0000 0000 0000 0000 0000 0000 0000 0101 b = a^b = a
    //^ 0000 0000 0000 0000 0000 0000 0000 0011 a = a^b = a

2,代碼實現

代碼如下(示例):

int main() 
{int a = 5; int b = 3; printf("交換前:a = %d,b = %d\n", a, b); a = a ^ b; b = a ^ b;  a = a ^ b;  printf("交換后:a = %d,b = %d\n", a, b); return 0; 
}

總結

上面是有關于交換兩個數的三種求法,但是實際中還是應用第一種方法,如果沒有硬性要求不能有中間變量建議使用第三種。如果大家還有其他的求解方法,歡迎大家留言小編及時補充。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/44528.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/44528.shtml
英文地址,請注明出處:http://en.pswp.cn/web/44528.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

淺談PostCSS

1. 背景 css的預處理器語言(比如 sass, less, stylus)的擴展性不好,你可以使用它們已有的功能,但如果想做擴展就沒那么容易。 sass是很常用的css預處理器語言,在webpack中要使用它,…

設計模式使用場景實現示例及優缺點(結構型模式——組合模式)

結構型模式 組合模式(Composite Pattern) 組合模式使得用戶對單個對象和組合對象的使用具有一致性。 有時候又叫做部分-整體模式,它使我們樹型結構的問題中,模糊了簡單元素和復雜元素的概念,客戶程序可以像處理簡單元…

小米起訴“小米”商標侵權,索賠500萬!

近日浙江麗水有家叫小米的公司,因為商標侵權被小米科技起訴索賠500萬,需要變更企業名稱,官網也不能用“小米智能大家居”等,還有其它的賠償,普推知產商標老楊分析,“小米智能大家居”“小米”,后…

【Flask從入門到精通:第九課:數據庫基本操作、數據表操作以及數據操作】

數據庫操作 數據庫驅動(drivers)模塊:pymysql、MySQLDB 數據庫基本操作 在SQLAlchemy中,添加、修改、刪除操作,均由數據庫會話(sessionSM)管理。 會話用 db.session 表示。在準備把數據寫入數據庫前,要先…

交易平臺Zero Hash現已支持SUI交易

Zero Hash是一家領先的加密貨幣和穩定幣基礎設施平臺,為包括Stripe、Shift4和Franklin Templeton在內的公司提供支持,現在也支持對SUI的訪問。此舉使Zero Hash的客戶及其終端用戶能夠使用SUI。 提供API和SDK以及專注于無縫連接法幣、加密貨幣和穩定幣的…

讀人工智能全傳11人工智能會出什么錯

1. 人工智能會出什么錯 1.1. 一些報道是公正合理的,不過坦白地說,大部分報道都愚蠢得無可救藥 1.2. 一些報道頗有知識性和引導性,而大部分則是杞人憂天式的恐嚇 1.3. 滑稽的報道迎合了大眾對人工智能的“終結者式恐懼” 1.3.1. 我們創造出…

html設計(兩種常見的充電效果)

第一種 完整代碼&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title&…

方便快捷傳文件—搭建rsync文件傳輸服務器

比如我們有一個服務器&#xff0c;想把各個機器的文件都通過腳本傳給這臺機&#xff0c;用sftp或者直接rsync就必須輸密碼&#xff0c;肯定不行&#xff0c;做等效性免密又麻煩&#xff0c;怎么辦呢&#xff0c;這么辦&#xff01; 在服務端 yum -y install rsync #編輯&…

Vue3 關于scss預編譯中:deep 其中的deep如何理解

在SCSS預處理器中&#xff0c;:deep是一個偽類選擇器&#xff0c;用于選擇一個元素的所有后代元素&#xff0c;無論它們在DOM結構中的層級深度如何。換句話說&#xff0c;:deep選擇器是一個類似于CSS中的后代選擇器&#xff0c;但是它可以不考慮嵌套層級的限制&#xff0c;而是…

Android MessageQueue 源碼分析

類注釋 /*** Low-level class holding the list of messages to be dispatched by a* {link Looper}. Messages are not added directly to a MessageQueue,* but rather through {link Handler} objects associated with the Looper.** <p>You can retrieve the Messa…

【FineGrip】全光學感知:一種新的通用遙感圖像解釋任務和細粒度數據集(IEEE TGRS 2024)

摘要 目前的遙感解譯模型通常集中于單一的任務&#xff0c;如檢測、分割或字幕。但是&#xff0c;針對特定任務設計的模型無法實現綜合多層次解譯。該領域也缺乏多任務聯合解譯數據集。本文提出Panoptic Perception&#xff0c;一個新的任務和一個新的細粒度數據集&#xff08…

apache Kylin系列介紹及配置

Apache Kylin是一個開源的分布式分析引擎,用于OLAP(聯機分析處理)數據處理。它專門設計用于處理大規模的數據集,并提供快速的查詢和分析能力。 apache Kylin架構: Apache Kylin是一個開源的分布式分析引擎,旨在提供高性能、低延遲的OLAP(聯機分析處理)能力。下面是Ap…

nvim工具介紹

1. **seoul256.vim**: 一個基于首爾色彩的低對比度 Vim 顏色方案&#xff0c;適用于 256 色終端或 GVim。 2. **vim-easy-align**: Vim 插件&#xff0c;用于對齊文本。 3. **vim-go**: Vim 的 Go 語言插件&#xff0c;支持語法高亮、自動縮進等。 4. **coc.nvim**: 集成了 LSP…

GESP CCF C++ 二級認證真題 2024年6月

第 1 題 小楊父母帶他到某培訓機構給他報名參加CCF組織的GESP認證考試的第1級&#xff0c;那他可以選擇的認證語言有幾種&#xff1f;&#xff08; &#xff09; A. 1 B. 2 C. 3 D. 4 第 2 題 下面流程圖在yr輸入2024時&#xff0c;可以判定yr代表閏年&#xff0c;并輸出 2月…

介紹一款數據準實時復制(CDC)中間件 `Debezium`

簡介 文章開頭先介紹一下什么是CDC。數據準實時復制(CDC)是目前行內實時數據需求大量使用的技術。常用的中間件有Canal、Debezium、Flink CDC等 下面我們做一下對比 各有優缺點吧,本主要介紹一下Debezium中間件。 Debezium是什么 Debezium是一個為變更數據捕獲(CDC)提供…

Windows圖形界面(GUI)-SDK-C/C++ - 列表框(List)

公開視頻 -> 鏈接點擊跳轉公開課程博客首頁 -> 鏈接點擊跳轉博客主頁 目錄 列表框(List) 控件樣式 創建控件 初始控件 消息處理 示例代碼 列表框(List) 控件樣式 列表框&#xff08;ListBox&#xff09;是Windows圖形界面開發中常用的控件&#xff0c;允許用戶從…

力扣第230題“二叉搜索樹中第K小的元素”

在本篇文章中&#xff0c;我們將詳細解讀力扣第230題“二叉搜索樹中第K小的元素”。通過學習本篇文章&#xff0c;讀者將掌握如何使用中序遍歷來找到二叉搜索樹中的第K小的元素&#xff0c;并了解相關的復雜度分析和模擬面試問答。每種方法都將配以詳細的解釋&#xff0c;以便于…

OpenAI終止對中國提供API服務,對國內AI市場產生重大沖擊?

6月25日&#xff0c;OpenAI突然宣布終止向包括中國在內的國家地區提供API服務&#xff0c;本月9日這一政策已經正式生效了&#xff01; 有人說&#xff0c;這個事件給中國AI行業帶來很大沖擊&#xff01;是這樣嗎&#xff1f;在展開討論前&#xff0c;我們先來看看什么是API服務…

會話固定攻擊

會話固定攻擊&#xff08;Session Fixation Attack&#xff09;是一種網絡攻擊&#xff0c;攻擊者試圖誘騙受害者使用攻擊者指定的會話ID&#xff0c;以便在受害者登錄后&#xff0c;攻擊者能夠竊取受害者的會話并冒充受害者進行操作。下面是一個形象的例子來解釋會話固定攻擊&…

8080端口映射外網不成功的原因

最近因為需要將群暉nas的8080端口映射到外網&#xff0c;但是路由器已經成功設置&#xff0c;群暉nas上對應端口的服務也已經部署好&#xff0c;可是如論如何也從外網訪問不到群暉服務器上&#xff0c;但是同樣是5000端口&#xff0c;群暉的外網管理端口就可以&#xff0c;最后…