Trang chủ Tin Học Lớp 11 Đoạn con có các số hạng dương liên tiếp có...

Đoạn con có các số hạng dương liên tiếp có tổng lớn nhất. nhất (nếu có nhiều đoạn con thoả mãn thì đọc ra màn hình : số đoạn con thoả mãn và các đoạn con đó )

Câu hỏi :

Đoạn con có các số hạng dương liên tiếp có tổng lớn nhất. nhất (nếu có nhiều đoạn con thoả mãn thì đọc ra màn hình : số đoạn con thoả mãn và các đoạn con đó )

Lời giải 1 :

phải này ko bạn: mình tự làm ko biết đúng ko

uses crt;

 var a:array[1..100] of longint;

 i,n,sld,j,max:integer;

 BEGIN

 clrscr;

 write('Vao n=');readln(n);

 for i:=1 to n do

    begin  write('a[',i,']=');readln(a[i]);end;

i:=1; max:=0;

While i<=n do

if a[i]>0 then

     begin

     sld:=0; j:=i;

        while ((j<=n)and(a[j]>0)) do

                   begin

                    inc(sld);

                     inc(j);

                    end;

           if sld>max  then max :=sld;

               inc(i,sld);

 end

Else inc(i);

writeln('So luong duong lien tiep nhieu nhat la:',max);

readln;

END.

#hlong210410

Thảo luận

Lời giải 2 :

uses crt;
var i,j,n,s,x,d,max:longint; a:array[1..10000]of longint;
begin
clrscr;
   write('Nhap n: ');readln(n);
   for i:=1 to n do
      begin
         write('Nhap phan tu thu ',i,': ');readln(a[i]);
      end;
   for i:=1 to n do
      begin
         j:=1;
         s:=0;
         while (a[i+j-1]>0) do
            begin
               s:=s+a[i+j-1];
               if s>max then
                  begin
                     max:=s;
                     d:=0;
                  end;
               if s=max then d:=d+1;
               inc(j);
            end;
      end;
   if max=0 then writeln('Khong co doan con thoa man') else
      begin
         writeln('Tong lon nhat: ',max);
         writeln('Co ',d,' doan con thoa man');
         for i:=1 to n do
            begin
               j:=1;
               s:=0;
               while (a[i+j-1]>0) do
                  begin
                     s:=s+a[i+j-1];
                     if s=max then
                        begin
                           for x:=i to i+j-1 do write(a[x],' ');
                           writeln;
                        end;
                     inc(j);
                  end;
            end;
      end;
readln
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ự 11

Lớp 11 - Năm thứ hai ở cấp trung học phổ thông, gần đến năm cuối cấp nên học tập là nhiệm vụ quan trọng nhất. Nghe nhiều đến định hướng sau này rồi học đại học. Ôi nhiều lúc thật là sợ, hoang mang nhưng các em hãy tự tin và tìm dần điều mà mình muốn là trong tương lai nhé!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247