移除二進位字串中所有的0所需的最小非相鄰對翻轉次數
在二進位字串中,翻轉一對相鄰位元可以輕鬆地從字串中刪除單一 0。然而,當我們需要從二進位字串中刪除所有 0 時,我們可能還需要翻轉不相鄰的位元對。在本文中,我們將討論如何確定從二進位字串中刪除所有 0 所需的非相鄰對翻轉的最小次數。
演算法
為了解決這個問題,我們將使用一個簡單的貪心演算法。這個想法是始終選擇彼此相距最遠並且之間至少有一個 0 的一對位。然後我們可以翻轉這兩位,有效地從字串中刪除一個 0。我們重複這個過程,直到所有的 0 都被刪除。
現在讓我們用 C 實作這個演算法。
範例
#include <iostream> #include <cstring> using namespace std; int main() { string s; s="100101000"; int n = s.size(); int cnt = 0; for (int i = 0; i < n; i++) { if (s[i] == '0') { cnt++; if (i+2 < n && s[i+2] == '0') { i += 2; } else { i++; } } } cout << cnt << endl; return 0; }
輸出
3
程式碼說明
上面的程式碼採用二進位字串作為輸入,並計算從字串中刪除所有 0 所需的非相鄰對翻轉的最小次數。現在讓我們詳細了解程式碼。
首先,我們將二進位字串作為輸入並將其儲存在字串變數「s」中。我們也將字串的大小儲存在整數變數“n”中。
string s; cin >> s; int n = s.size();
接下來,我們初始化變數「cnt」來儲存字串中 0 的數量。然後我們使用 for 循環迭代該字串。對於遇到的每個 0,我們都會增加 0 的計數並檢查接下來的兩位是否也是 0。如果是,我們透過將索引增加 2 來翻轉這對位。否則,我們透過將索引增加 1 來僅翻轉相鄰的位對。
int cnt = 0; for (int i = 0; i < n; i++) { if (s[i] == '0') { cnt++; if (i+2 < n && s[i+2] == '0') { i += 2; } else { i++; } } }
最後,我們輸出從字串中刪除所有 0 所需的非相鄰對翻轉的計數。
cout << cnt << endl;
測試案例範例
讓我們考慮二進位字串「100101000」。可以使用上述演算法計算從該字串中刪除所有 0 所需的非相鄰對翻轉的最小次數。
首先,我們在位置 2 遇到 0。我們翻轉 (1,3) 對以獲得字串「110101000」。然後我們在位置 5 遇到下一個 0。我們翻轉 (1,7) 對以獲得字串「111101000」。然後我們在位置 8 遇到下一個 0。我們翻轉 (1,9) 對以獲得字串「111111000」。現在所有 0 都已從字串中刪除。
從字串中刪除所有 0 所需的非相鄰對翻轉次數為 3。我們可以透過對輸入字串「100101000」運行上述 C 程式碼來驗證這一點。
結論
在本文中,我們討論瞭如何確定從二進位字串中刪除所有 0 所需的非相鄰對翻轉的最小次數。我們使用簡單的貪心演算法來解決這個問題,並用C 程式碼實作。我們還提供了一個範例測試案例來說明演算法的工作原理。
以上是移除二進位字串中所有的0所需的最小非相鄰對翻轉次數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

玩家在深空之眼中進行遊戲時可以翻轉螢幕進行遊戲,有很多用戶不知道深空之眼怎麼翻轉螢幕,玩家需要在控制中心打開支援螢幕旋轉的選項,再回到遊戲中即可。深空之眼怎麼翻轉螢幕1、打開手機的螢幕,用手指從螢幕底部向上滑動。 2、隨後即可開啟控制中心了,在控制中心的右上角就是關閉螢幕旋轉的開關。 3.點擊它即可打開螢幕旋轉,此時會發現控制旋轉的圖示在控制中心以高亮顯示。 4.開啟支援螢幕旋轉的應用軟體時,就會隨著手機方向的改變而旋轉了。

EDVAC的兩個重大的改進:一是採用二進制,二是完成了存貯程序,可以自動地從一個程序指令進到下一個程序指令,其作業可以透過指令自動完成。 「指令」包括資料和程序,把它們用碼的形式輸入到機器的記憶裝置中,即用記憶資料的同一記憶裝置存貯執行運算的命令,這就是所謂存貯程序的新概念。

如何透過純CSS實現圖片的翻轉效果的方法和技巧前言:在Web開發中,我們經常需要為網頁添加一些動畫效果來增加使用者體驗。圖片的翻轉效果是其中一個常見的效果之一。透過純CSS來實現圖片的翻轉不僅簡單方便,還可以避免使用JavaScript等其他語言帶來的額外開銷。本文將介紹如何透過純CSS實現圖片的翻轉效果,並提供具體的程式碼範例。一、利用CSS3的transfo

二進位演算法是一種基於二進制數的運算方法,其基本運算包括加法、減法、乘法和除法。除了基本運算外,二進位演算法還包括邏輯運算、位移運算等操作。邏輯運算包括與、或、非等操作,位移運算包括左移和右移操作。這些操作都有對應的規則和操作數的要求。

HTML、CSS和jQuery:建立一個漂亮的卡片翻轉特效在網頁設計中,特效的應用程式可以增加頁面的互動性和視覺效果。卡片翻轉特效是一種常見的特效,它可以帶給使用者更生動、有趣的瀏覽體驗。本文將介紹如何使用HTML、CSS和jQuery建立一個漂亮的卡片翻轉特效,並提供具體的程式碼範例。首先,我們需要準備好HTML的基本結構。我們將使用兩個div元素來表示卡片的正

二進制數以1和0表示。 16位元的十六進位數係統為{0,1,2,3…..9,A(10),B(11),……F(15)}為了從二進位表示轉換為十六進位表示,位元串id被分組為4位元區塊,從最低有效側開始稱為半位元組。每個區塊都替換為相應的十六進制數字。讓我們看一個範例,以清楚地了解十六進制和二進制數字表示。 001111100101101100011101 3 E 5 B&nb

Golang如何讀取二進位檔案?二進位檔案是以二進位形式儲存的文件,其中包含了電腦能夠識別和處理的資料。在Golang中,我們可以使用一些方法來讀取二進位文件,並將其解析成我們想要的資料格式。以下將介紹如何在Golang中讀取二進位文件,並給出具體的程式碼範例。首先,我們需要使用os包中的Open函數開啟二進位文件,這將會傳回一個文件物件。然後,我們可以使

電腦採用二進位的主要原因:1、電腦是由邏輯電路組成,邏輯電路通常只有兩個狀態,開關的接通與斷開,這兩種狀態剛好可以用「1」與「0」表示;2、二進位只使用0和1兩個數字,傳輸和處理時不易出錯,因而可以保障電腦具有很高的可靠性。
