Trang chủ Tin Học Lớp 9 Tìm đoạn có tổng dương dài nhất Vd 10 -5...

Tìm đoạn có tổng dương dài nhất Vd 10 -5 -2 -3 4 -6 7 -8 9 -1 -20 Output 3 9 Giới hạn thời gian <1s |ai| <= 10^9 1<=n<=10^6 Mình cần ý tưởng code

Câu hỏi :

Tìm đoạn có tổng dương dài nhất Vd 10 -5 -2 -3 4 -6 7 -8 9 -1 -20 Output 3 9 Giới hạn thời gian <1s |ai| <= 10^9 1<=n<=10^6 Mình cần ý tưởng code theo kiểu gì cũng được

Lời giải 1 :

tính trc mảng f vs f[i]=sum(a[1],a[2],..,a[i]);

Tính mảng minn vs minn[i]=chỉ số nhỏ nhất từ f[0],f[1],..f[i];

rồi h xài vòng lặp while kt từng cặp l,r rồi xuất thôi.

Code full:

#include <bits/stdc++.h>
using namespace std;
int n,a[100001],minn[100001];
long long f[100001];
void input()
{
    cin>>n;
    for (int i=1;i<=n;i++)
    {
        cin>>a[i];
        f[i]=f[i-1]+a[i];
        if (f[i]<f[minn[i-1]]) minn[i]=i;
        else minn[i]=minn[i-1];
    }
}
void solve()
{
    int k=minn[n],h=n,s=0,t1,t2;
    while (true)
    {
        while (f[h]-f[k]<=0&&k<h) h--;
        if (s<h-k)
        {
            t1=k+1;
            t2=h;
            s=h-k;
        }
        if (k==0) break;
        k=minn[k-1];
    }
    cout<<t1<<" "<<t2;
}

int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    freopen("ps.inp","r",stdin);
    freopen("ps.out","w",stdout);
    input();
    solve();
}

Mà ông học thầy Vinh ak, bài này trong level 5.1

Thảo luận

-- bạn giỏi tin quá nhỉ
-- :v
-- :vv

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ự 9

Lớp 9 - Là năm cuối ở cấp trung học cơ sở, sắp phải bước vào một kì thi căng thẳng và sắp chia tay bạn bè, thầy cô và cả kì vọng của phụ huynh ngày càng lớn mang tên "Lên cấp 3". Thật là áp lực nhưng các em hãy cứ tự tin vào bản thân là sẻ vượt qua nhé!

Nguồn : ADMIN :))

Liên hệ hợp tác hoặc quảng cáo: gmail

Điều khoản dịch vụ

Copyright © 2021 HOCTAPSGK