目錄
演算法
範例
輸出
程式碼說明
測試案例範例
結論
首頁 後端開發 C++ 移除二進位字串中所有的0所需的最小非相鄰對翻轉次數

移除二進位字串中所有的0所需的最小非相鄰對翻轉次數

Sep 04, 2023 pm 01:09 PM
二進位 翻轉 非相鄰

移除二進位字串中所有的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中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

深空之眼怎麼翻轉螢幕 深空之眼怎麼翻轉螢幕 Mar 22, 2024 pm 10:41 PM

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

EDVAC有哪兩個重大的改進 EDVAC有哪兩個重大的改進 Mar 02, 2023 pm 02:58 PM

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

如何透過純CSS實現圖片的翻轉效果的方法和技巧 如何透過純CSS實現圖片的翻轉效果的方法和技巧 Oct 20, 2023 am 10:57 AM

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

二進位演算法怎麼算 二進位演算法怎麼算 Jan 19, 2024 pm 04:38 PM

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

HTML、CSS和jQuery:建立一個漂亮的卡片翻轉特效 HTML、CSS和jQuery:建立一個漂亮的卡片翻轉特效 Oct 27, 2023 pm 01:43 PM

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

如何使用C語言將二進位轉換為十六進位? 如何使用C語言將二進位轉換為十六進位? Sep 01, 2023 pm 06:57 PM

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

Golang如何讀取二進位檔案? Golang如何讀取二進位檔案? Mar 21, 2024 am 08:27 AM

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

電腦內部採用二進位的主要原因是什麼? 電腦內部採用二進位的主要原因是什麼? Apr 04, 2019 pm 02:25 PM

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

See all articles