Trang chủ Tin Học Lớp 8 C++ Cho Cho dãy số nguyên A = (a1, a2,...

C++ Cho Cho dãy số nguyên A = (a1, a2, ..., an) (1 ≤ n ≤ 106 , -106 ≤ ai ≤ 106 ). Hãy tìm một đoạn dài nhất gồm các phần tử liên tiếp trong dãy A: (aL, aL+1, .

Câu hỏi :

C++ Cho Cho dãy số nguyên A = (a1, a2, ..., an) (1 ≤ n ≤ 106 , -106 ≤ ai ≤ 106 ). Hãy tìm một đoạn dài nhất gồm các phần tử liên tiếp trong dãy A: (aL, aL+1, ..., aH) có tổng bằng 0 Dữ liệu: SZERO.INP • Dòng 1: Chứa số n • Dòng 2: Chứa n số a1, a2, ..., an theo đúng thứ tự cách nhau ít nhất một dấu cách Dữ liệu vào luôn được cho hợp lý để tồn tại một đoạn các phần tử liên tiếp trong dãy A có tổng bằng 0. Kết quả: SZERO.OUT • Chỉ gồm một dòng ghi hai số và cách nhau ít nhất một dấu cách. Ví dụ: SZERO.INP SZERO.OUT 9 2 7 5 -3 -2 4 -9 -2 1 2 8 Ràng buộc: • Subtask1: 30% số test đầu tiên tương ứng 1 ≤ n ≤ 500 • Subtask2: 30% số test tiếp theo tương ứng 501 ≤ n ≤ 5000 3 • Subtask3: 20% số test tiếp theo tương ứng 5001 ≤ n ≤ 105 • Subtask4: 20% số test cuối cùng tương ứng với 105

Lời giải 1 :

#include <iostream>
#include <map>
using namespace std;
typedef long long ll;

ll s;
int n, len, p, a;
map<ll, int> m;

int main() {
    p = -1;
    cin >> n;
    for (int i = 1;i <= n;i++) {
        cin >> a;
        s += a;
        if (s == 0) {
            p = 0;
            len = i;
        }
        
        if (m[s]) {
            if (i - m[s] > len) {
                len = i - m[s];
                p = m[s];
            }
        } else {
            m[s] = i;
        }
    }
    if (p != -1) {
        cout << p + 1 << ' ' << p + len; 
    } else {
        cout << -1;
    }
}

Thảo luận

-- thank you

Bạn có biết?

Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.

Nguồn : Wikipedia - Bách khoa toàn thư

Tâm sự 8

Lớp 8 - Năm thứ ba ở cấp trung học cơ sở, học tập bắt đầu nặng dần, sang năm lại là năm cuối cấp áp lực lớn dần nhưng các em vẫn phải chú ý sức khỏe nhé!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247