如果你曾經使用過C ,你一定知道什麼是子陣列以及它們有多有用。眾所周知,在 C 中,我們可以輕鬆解決多個數學問題。因此,在本文中,我們將解釋如何在 C 中藉助這些子數組找到 M 個奇數的完整資訊。
在這個問題中,我們需要找到由給定數組組成的許多子數組和整數 m,其中每個子數組恰好包含 m 個奇數。這是這種方法的簡單範例-
Input : array = { 6,3,5,8,9 }, m = 2 Output : 5 Explanation : Subarrays with exactly 2 odd numbers are { 3,5 }, { 6,3,5 }, { 3,5,8 }, { 5,8,9 }, { 6,3,5,8 }, { 3,5,8,9 } Input : array = { 1,6,3,2,5,4 }, m = 2 Output : 6 Explanation : Subarrays with exactly 2 odd numbers are { 1,6,3 }, { 3,2,5 }, { 1,6,3,2 }, { 6,3,2,5 }, { 3,2,5,4 }, { 6,3,2,5,4 }
第一種方法
在這種方法中,所有可能的子數組都是從給定數組生成的,並且檢查每個子數組是否剛好有m 個奇數。這是一種簡單的生成和查找方法,該方法的時間複雜度為 O(n2)。
範例
#include <bits/stdc++.h> using namespace std; int main (){ int a[] = { 1, 6, 3, 2, 5, 4 }; int n = 6, m = 2, count = 0; // n is size of array, m numbers to be find in subarrays, // count is number of subarray with m odd numbers for (int i = 0; i < n; i++){ // outer loop to process each element. int odd = 0; for (int j = i; j < n; j++) {// inner loop to find subarray with m number if (a[j] % 2) odd++; if (odd == m) // if odd numbers become equals to m. count++; } } cout << "Number of subarrays with n numbers are: " << count; return 0; }
輸出
Number of subarrays with n numbers are: 6
上述程式碼說明
在這段程式碼中,我們使用巢狀迴圈來尋找m個奇數的子數組,外層循環用於遞增“i”,這將用於處理數組中的每個元素。
內循環用於查找子數組並處理元素,直到奇數計數器達到m,為每個找到的子數組增加結果計數器計數,最後打印計數中存儲的結果
第二種方法
另一種方法是建立一個陣列來儲存「i」個奇數前綴的數量,對每個元素進行處理,並增加奇數的數量每找到一個奇數。
當奇數的個數超過或等於 m 時,將前綴數組中 (odd - m ) 位置的數字加到其中。
當奇數變成大於或等於 m,我們計算形成的子數組的數量,直到索引和「odd - m」數字加到 count 變數。處理完每個元素後,結果將儲存在 count 變數中。
範例
#include <bits/stdc++.h> using namespace std; int main (){ int array[ ] = { 1, 6, 3, 2, 5, 4 }; int n = 6, m = 2, count = 0, odd = 0, i; int prefix_array[n + 1] = { 0 }; // outer loop to process every element of array for (i = 0; i < n; i++){ prefix_array[odd] = prefix_array[odd] + 1; // implementing value at odd index in prefix_array[ ] // if array element is odd then increment odd variable if (array[i] % 2 == 0) odd++; // if Number of odd element becomes equal or greater than m // then find the number of possible subarrays that can be formed till the index. if (odd >= m) count += prefix_array[odd - m]; } cout << "Number of subarrays with n numbers are: " << count; return 0; }
輸出
Number of subarrays with n numbers are: 6
上述程式碼的說明
使用起始值初始化陣列和變數-
int array[ 6 ] = { 1, 6, 3, 2, 5, 4 }; int n = 6, m = 2, count = 0, odd = 0, i; int prefix_array[n + 1] = { 0 };
在此,我們用數組的大小初始化變數n,用要尋找的多個奇數初始化變數m,用0 初始化計數以保持可能的子數組的計數,用0 初始化奇數,用大小為n 1 的prefix_array 初始化變數n 0 .
理解循環
for (i = 0; i < n; i++){ prefix_array[odd] = prefix_array[odd] + 1; if (array[i] % 2 == 0) odd++; if (odd >= m) count += prefix_array[odd - m]; }
在此循環中,我們在prefix_array[ ] 中的奇數索引處實作值,然後如果找到奇數則遞增奇數變數。我們發現當奇數變數等於或大於 m 時,可以形成子數組的數量,直到索引。
最後,我們印出 count 變數中儲存的 m 個奇數的子數組數,並且得到輸出。
結論
在本文中,我們透過兩種方法了解了尋找m 個奇數子數組的數量的方法-
產生每個子數組並檢查其中是否有m 個奇數,並遞增找到的每個子數組的計數。這段程式碼的時間複雜度是O(n2)。
高效的方法,遍歷數組的每個元素並創建一個前綴數組,然後用前綴數組的幫助。這段程式碼的時間複雜度是O(n)。
希望本文對您理解問題和解決方案有所幫助。
以上是使用C++編程,找出具有m個奇數的子數組的數量的詳細內容。更多資訊請關注PHP中文網其他相關文章!

C 學習者和開發者可以從StackOverflow、Reddit的r/cpp社區、Coursera和edX的課程、GitHub上的開源項目、專業諮詢服務以及CppCon等會議中獲得資源和支持。 1.StackOverflow提供技術問題的解答;2.Reddit的r/cpp社區分享最新資訊;3.Coursera和edX提供正式的C 課程;4.GitHub上的開源項目如LLVM和Boost提陞技能;5.專業諮詢服務如JetBrains和Perforce提供技術支持;6.CppCon等會議有助於職業

C#適合需要高開發效率和跨平台支持的項目,而C 適用於需要高性能和底層控制的應用。 1)C#簡化開發,提供垃圾回收和豐富類庫,適合企業級應用。 2)C 允許直接內存操作,適用於遊戲開發和高性能計算。

C 持續使用的理由包括其高性能、廣泛應用和不斷演進的特性。 1)高效性能:通過直接操作內存和硬件,C 在系統編程和高性能計算中表現出色。 2)廣泛應用:在遊戲開發、嵌入式系統等領域大放異彩。 3)不斷演進:自1983年發布以來,C 持續增加新特性,保持其競爭力。

C 和XML的未來發展趨勢分別為:1)C 將通過C 20和C 23標準引入模塊、概念和協程等新特性,提升編程效率和安全性;2)XML將繼續在數據交換和配置文件中佔據重要地位,但會面臨JSON和YAML的挑戰,並朝著更簡潔和易解析的方向發展,如XMLSchema1.1和XPath3.1的改進。

現代C 設計模式利用C 11及以後的新特性實現,幫助構建更靈活、高效的軟件。 1)使用lambda表達式和std::function簡化觀察者模式。 2)通過移動語義和完美轉發優化性能。 3)智能指針確保類型安全和資源管理。

C 多線程和並發編程的核心概念包括線程的創建與管理、同步與互斥、條件變量、線程池、異步編程、常見錯誤與調試技巧以及性能優化與最佳實踐。 1)創建線程使用std::thread類,示例展示瞭如何創建並等待線程完成。 2)同步與互斥使用std::mutex和std::lock_guard保護共享資源,避免數據競爭。 3)條件變量通過std::condition_variable實現線程間的通信和同步。 4)線程池示例展示瞭如何使用ThreadPool類並行處理任務,提高效率。 5)異步編程使用std::as

C 的內存管理、指針和模板是核心特性。 1.內存管理通過new和delete手動分配和釋放內存,需注意堆和棧的區別。 2.指針允許直接操作內存地址,使用需謹慎,智能指針可簡化管理。 3.模板實現泛型編程,提高代碼重用性和靈活性,需理解類型推導和特化。

C 適合系統編程和硬件交互,因為它提供了接近硬件的控制能力和麵向對象編程的強大特性。 1)C 通過指針、內存管理和位操作等低級特性,實現高效的系統級操作。 2)硬件交互通過設備驅動程序實現,C 可以編寫這些驅動程序,處理與硬件設備的通信。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

WebStorm Mac版
好用的JavaScript開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 Linux新版
SublimeText3 Linux最新版

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