Trang chủ Tin Học Lớp 8 Bài 2: (5,0 điểm) Dãy số Cho dãy gồm N...

Bài 2: (5,0 điểm) Dãy số Cho dãy gồm N số nguyên khác không: Ai, Az, .., An. Hãy tìm dãy con gồm nhiều phần tử nhất có tính chất cùng dương hoặc cùng âm (n

Câu hỏi :

NNLT j cũng đc nha Ưu tiên (Pasca/C/C++):>

image

Lời giải 1 :

#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll n, i, MAX, vt, k, j;
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    cin >> n;
    ll a[n + 5];
    for (i = 1; i <= n; i++)
    {
        cin >> a[i];
    }
    for (j = 1; j <= n; j++)
    {
        k = 0;
        for (i = j; i <= n; i++)
        {
            if (a[i] < 0)
            {
                k++;
            }
            else
            {
                break;
            }
        }
        if (k > MAX)
        {
            MAX = k;
            vt = j;
        }
        for (i = j; i <= n; i++)
        {
            if (a[i] > 0)
            {
                k++;
            }
            else
            {
                break;
            }
        }
        if (k > MAX)
        {
            MAX = k;
            vt = j;
        }
    }
    if (MAX == 1)
    {
        cout << -1;
    }
    else
    {
        cout << MAX << " " << vt;
    }
    return 0;
}

Thảo luận

Lời giải 2 :

program vd;

uses crt;

var a:array[1..1000] of integer;

    n,i,j,x,l,d,max,l1,d1 : integer;

begin

readln(n);

for i:=1 to n do read(a[i]);

max:=0;

for i:=1 to n do

  begin

    l:=0;

    d:=0;

    j:=i+1;;

    l:=1;

    if a[i] > 0 then

      begin

        while j <= n do

           begin

            if a[j] > 0 then inc(l)

            else break;

            inc(j);

           end;

        if l > max then

         begin

           max:=l;

           l1 :=l;

           d1:=i;

         end;

      end;

     if a[i] < 0 then

      begin

        while j <= n do

           begin

            if a[j] < 0 then inc(l)

            else break;

            inc(j);

           end;

        if l > max then

         begin

           max :=l;

           l1 :=l;

           d1:=i;

         end;

      end;

  end;

if l1=1 then write('-1') else

write(l1,' ',d1);

end.

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 :))

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

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

Copyright © 2021 HOCTAPSGK