Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

ค้นหาการนับจำนวนคู่ที่ต่อเนื่องกันสูงสุดใน C++


สมมติว่าเรามีอาร์เรย์ A ที่มีองค์ประกอบ n เราต้องหาจำนวนสูงสุดของเลขคู่ที่อยู่ติดกันในอาร์เรย์ที่กำหนด ดังนั้นหากอาร์เรย์เป็นเหมือน A =[1, 2, 3, 4, 6, 8, 7] การนับจะเป็น 3

เราสามารถแก้ปัญหานี้ได้อย่างง่ายดาย เราต้องการตัวแปรนับสองตัว ตัวหนึ่งคือ max_current และอีกตัวคือ max_till_now หากพบเลขคู่ ให้เพิ่ม max_current แล้วเปรียบเทียบกับ max_till_now ทุกครั้งที่พบองค์ประกอบคี่จะรีเซ็ต max_count เป็น 0

ตัวอย่าง

#include<iostream>
using namespace std;
int maxEvenContiguous(int arr[], int n) {
   int max_current = 0, max_till_now = 0;
   for (int i = 0; i < n; i++) {
      if (arr[i] % 2 != 0)
         max_current = 0;
      else {
         max_current++;
         max_till_now = max(max_current, max_till_now);
      }
   }
   return max_till_now;
}
int main() {
   int arr[] = {1, 2, 3, 4, 6, 8, 7};
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << "Max contiguous even number count: " << maxEvenContiguous(arr, n);
}

ผลลัพธ์

Max contiguous even number count: 3