最長非遞增子序列在一個二進位字串中
在這個問題中,我們需要找到給定字串的最長非遞增子序列。
非遞增的意思是字元要麼相同,要麼按降序排列。由於二進位字串僅包含“0”和“1”,因此產生的字串應以“1”開頭並以“0”結尾,或以“0”或“1”開頭和結尾。
為了解決這個問題,我們將統計字串每個位置的前綴“1”和後綴“0”,並找到前綴“1”和後綴“0”的最大和。
問題陳述 - 我們給了二進位字串 str。我們需要從給定的字串中找到最長的非遞增子序列。
範例
Input – str = "010100"
Output – 4
說明
最長的非遞增子序列是「1100」。
Input – str = "010110010"
Output – 6
說明
最長的非遞增子序列是「111000」。
Input – str = ‘00000000’
Output – 8
說明
最長的非遞增子序列是‘00000000’,它等於給定的字串。
方法 1
在這個方法中,我們將在陣列中為每個索引儲存前綴「1」和後綴「0」的計數。之後,我們從兩個陣列中的相同索引取得值,將它們相加,並找到最大總和。
演算法
步驟 1 - 定義 pre1s 和 suffix0s 陣列來儲存前綴 1 和後綴 0。另外,將所有數組元素初始化為 0。
步驟 2 - 使用 for 迴圈遍歷字串並計算每個索引的前綴 1。如果我> 0,則將前一個元素的值加到目前元素。
步驟 3 - 如果目前字元為“1”,則將 pre1s[i] 的目前值加 1。
第 4 步 - 現在,計算給定字串中的後綴 0。從末尾開始遍歷字串。
步驟 5 - 如果“I”的值不等於“n – 1”,則取得“I 1”元素的值並將其新增至目前元素。
第 6 步 - 如果目前元素為“0”,則向目前元素加 1。
第 7 步 - 現在,用 0 初始化「res」變數。
第 8 步 - 使用循環迭代“pre1s”和“suffix0s”。
第 9 步 - 從「pre1s」和「suffix0s」陣列中的第 i 個索引取得值,並將它們相加。另外,如果「sum」大於「res」變數的目前值,則用「sum」值來變更「res」變數值。
第 10 步 - 傳回「res」變數的值。
範例
對於輸入‘010100’,前綴數組為 [0, 1, 1, 2, 2, 2],後綴 0 數組為 [4, 3, 3, 2, 2, 1]。 sum 陣列將為 [4, 4, 4, 4, 4, 1],sum 陣列中的最大值為 4。因此,答案將為 4。
#include <bits/stdc++.h> using namespace std; int getMaxLength(string str, int n){ // To store the prefix count of '1's and suffix count of '0's int pre1s[n] = {0}, suffix0s[n] = {0}; for (int i = 0; i < n; i++){ // get the prefix count of '1's if (i > 0){ pre1s[i] += pre1s[i - 1]; } // If the current character is '1', then update the pre1s array by adding 1; else, keep it as it is. if (str[i] == '1'){ pre1s[i] += 1; } } // get suffix count of '0's for (int i = n - 1; i >= 0; i--) { // add the suffix count of '0's if (i != n - 1) suffix0s[i] += suffix0s[i + 1]; // If the current character is '0', then update the suffix0s array by adding 1; else, keep it as it is. if (str[i] == '0') suffix0s[i] += 1; } // to store the final result value int res = 0; // iterate over the pre1s[] and suffix0s[] array and find the maximum value of pre1s[i] + suffix0s[i] for (int i = 0; i < n; i++){ res = max(res, pre1s[i] + suffix0s[i]); } // Return the result return res; } // Driver Code int main(){ string str = "010100"; int N = str.length(); cout << "The length of the longest non-increasing subsequence in the given binary string is - " << getMaxLength(str, N); return 0; }
輸出
The length of the longest non-increasing subsequence in the given binary string is - 4
時間複雜度 - O(N),因為我們需要初始化前綴 1 和後綴 0 的陣列。
空間複雜度 - O(N),因為我們將前綴 1 和後綴 0 儲存在陣列中
方法2
在這種方法中,我們將首先計算零的總數。之後,我們開始遍歷字串,繼續計算“1”,如果找到 0,則減少“0”。此外,我們在每次迭代中將 0 和 1 的計數相加,並找到最大結果值。
演算法
第1 步 - 定義'count1'、'count0' 和'res' 變量,並用0 初始化它們,分別儲存1、0 的計數和最終結果.
第 2 步 - 透過遍歷字串並將其儲存在「count0」變數中來計算零的總數。
第 3 步 - 現在,使用循環迭代字串。
步驟4 - 在循環中,如果目前字元為“1”,則將“count1”的值增加1,否則將“count0”的值減少1.
第 5 步 - 另外,將「res」和「count0 count1」中的最大值儲存到「res」變數中。
第 6 步 - 當迴圈終止時,傳回「res」變數的值。
範例
#include <bits/stdc++.h> using namespace std; int getMaxLength(string str, int n){ int count1 = 0, count0 = 0; int res = 0; // counting total zeros in the string for (int i = 0; i < n; i++){ if (str[i] == '0') count0++; } // counting 1s from left, subtracting zeros from total zeros and adding both counts. for (int i = 0; i < n; i++){ if (str[i] == '1') count1++; else count0--; res = max(res, count1 + count0); } return res; } int main(){ string str = "010110010"; int N = str.length(); cout << "The length of the longest non-increasing subsequence in the given binary string is - " << getMaxLength(str, N); return 0; }
輸出
The length of the longest non-increasing subsequence in the given binary string is - 6
時間複雜度 - O(N),因為我們計算字串中零的總數並遍歷字串以找到最長的子序列。
空間複雜度 - O(1)
結論
這裡,兩種方法具有相同的時間複雜度但不同的空間複雜度。第二種方法在我們優化程式碼時使用常數空間,但第一種方法使用動態空間來儲存前綴 1 和後綴 0 的總數。
以上是最長非遞增子序列在一個二進位字串中的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

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

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

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

小紅書作為一個生活方式分享平台,越來越多的用戶選擇在這裡發布自己的影片內容,與其他用戶分享生活點滴。許多用戶在發布影片時,可能會遇到一個問題:如何查看自己或他人發布影片的時間?一、如何查看小紅書發布影片的時間? 1.查看自己發布影片的時間要查看自己發布影片的時間,首先要開啟小紅書應用程式並登入個人帳號。在個人主頁介面下方,會有一個標有「創作」字樣的選項,點擊進入後,會看到一個名為「影片」的欄位。在這裡,你可以瀏覽所有已發布的影片列表,並輕鬆查閱發佈時間。每個影片的右上角都有一個「查看詳情」按鈕,點擊後

在這個問題中,我們需要找到給定字串的最長非遞增子序列。非遞增的意思是字元要麼相同,要麼按降序排列。由於二進位字串僅包含“0”和“1”,因此產生的字串應以“1”開頭並以“0”結尾,或以“0”或“1”開頭和結尾。為了解決這個問題,我們將統計字串每個位置的前綴“1”和後綴“0”,並找到前綴“1”和後綴“0”的最大和。問題陳述-我們給了二進位字串str。我們需要從給定的字串中找到最長的非遞增子序列。範例Input–str="010100"Output–4說明最長的非遞

在給定的問題中,我們得到一個由0和1組成的字串;我們需要找出以1開頭的所有排列的總數。由於答案可能是一個巨大的數字,所以我們將其取模1000000007後輸出。 Input:str="10101001001"Output:210Input:str="101110011"Output:56我們將透過應用一些組合數學和建立一些公式來解決這個問題。解的方法在這個方法中,我們將計算0和1的數量。現在假設n是我們字串中出現的1的數量,m是我們字串中出現的0

pack()函數將資料打包到二進位字串中。語法pack(format,args)參數格式-要使用的格式。以下是可能的值-a-NUL填充字串A-空格填充字串h-十六進位字串,低半位元組在前H-十六進位字串,高半位元組在前c-帶符號字元C-無符號字元s-帶符號短字元(始終為16位,機器字節順序)S-無符號短整型(始終為16位,機器字節順序)n-無符號短整型(始終為16位,大端字節順序)v-無符號短整型(始終為16位,小端字節順序)i-有符號整數(取決於機器的大小和字節順序)I-無符號整數(取決

問題陳述我們有一個字串str和一個二進位字串B。兩個字串的長度都等於N。我們需要檢查是否可以透過在字串B中包含不相等字符的任意索引對上多次交換其字符,使字串str成為回文字串。範例範例輸入str=‘AAS’B=‘101’輸出‘YES’Explanation的中文翻譯為:解釋我們可以交換str[1]和str[2],因為B[1]和B[2]不相等。最終的字串可以是'ASA'。輸入str=‘AASS’B=‘1111’輸出‘No’Explanation的中文翻譯為:解釋我們無法讓字串回文,

本文的目的是實現一個程序,用於計算由一個子字串重複連接而成的長度為N的二進位字串的數量。目標是確定透過重複連接給定文字的單一子字串,可以創建多少長度為N的二進位字串,其中N是一個正整數。問題陳述實作一個程序,用於計算重複連接子字串的長度為N的二進位字串的數量。範例範例1LetustaketheInput,N=3Output:2Explanation的中文翻譯為:解釋下面列出了長度為N=3的可行二進位字串,其中重複連接了一個子字串。 "000":Thesubstr

在本文中,我們將討論一個有趣的問題,涉及字串操作和博弈論領域:「透過刪除非空子字串來清空二進位字串,找到剩餘0最少的玩家」。這個問題探索了使用二進位字串進行競技遊戲的概念。我們的目標是在遊戲結束後找出剩餘0最少的玩家。我們將討論這個問題,提供一個C++程式碼實現,並透過一個例子來解釋這個概念。理解問題陳述給兩個玩家一個二進位字串,他們輪流玩遊戲。在每一回合中,玩家移除至少包含一個「1」的非空子字串。當字串變空或字串中沒有“1”時,遊戲結束。無法採取行動的玩家輸掉遊戲。任務是找到最終0

給定兩個相同長度的二進位字串str1和str2,我們必須透過從給定的相同長度的字串中選擇子字串來最大化給定的函數值。給定的函數是這樣的-fun(str1,str2)=(len(子字串))/(2^xor(sub1,sub2))。這裡,len(substring)是第一個子字串的長度,而xor(sub1,sub2)是給定子字串的異或,因為它們是二進位字串,所以這是可能的。範例Input1:stringstr1=10110&stringstr2=11101Output:3說明我們
