Tìm dãy con bằng nhau liên tiếp dài nhất trong 1 dãy số

Lập trình C++

Bài toán. Tìm dãy con bằng nhau liên tiếp dài nhất trong 1 dãy số. Yêu cầu: ghi ra tổng số phần tử và liệt kê các phần tử của dãy con bằng nhau.

MAXBN.INP

MAXBN.OUT

10

2 2 1 1 1 1 3 4 4 4

4

1 1 1 1

Code tham khảo:

#include <iostream>
using namespace std;

int main() {
    freopen("MAXBN.INP","r",stdin);
    freopen("MAXBN.OUT","w",stdout);
    int n, a[1000], b[1000];
    cin >> n;
    for(int i=0; i < n; i++) {
        cin >> a[i];
        b[i] = 1;
    }
    for(int i=n-1; i>0; i--) {
        if(a[i] == a[i-1]) {
            b[i-1] += b[i];
        }
    }
    int m = b[0];
    for (int i=1; i<n; i++) {
        if(m < b[i]) m = b[i];
    }
    cout << m << endl;
    int vt = 0;
    for (int i = 0; i < n; i++) {
        if(b[i] == m) vt = i;
    }
    for (int i = vt; i < vt + m; i++) {
        cout << a[i] << " ";
    }
    return 0;
}

Trả lời

Email của bạn sẽ không được hiển thị công khai. Các trường bắt buộc được đánh dấu *