Trang chủ Tin Học Lớp 9 Tìm dãy con gồm m phần tử (m

Tìm dãy con gồm m phần tử (m

Câu hỏi :

Tìm dãy con gồm m phần tử (m tính tổng 4 số liên tiếp có tổng là lớn nhất khi đó màn hình sẽ đưa ra tổng lớn nhất của các số 1; 8; 9; 7

Lời giải 1 :

Đùng function:

uses crt;
var i,n,m,max:longint; a:array[1..10000]of longint;
function s(i:longint):longint;
var j:longint;
begin
   s:=0;
   for j:=i to i+m-1 do 
      s:=s+a[j];   
end;
begin
clrscr;
   write('Nhap n,m: ');readln(n,m);
   for i:=1 to n do 
      begin 
         write('Nhap phan tu thu ',i,': ');readln(a[i]); 
      end;
   for i:=1 to n-m+1 do 
      If s(i)>max then max:=s(i);
   writeln(max);
readln
end.   

Không dùng function:

uses crt;
var i,j,s,n,m,max:longint; a:array[1..10000]of longint;
begin
clrscr;
   write('Nhap n,m: ');readln(n,m);
   for i:=1 to n do 
      begin 
         write('Nhap phan tu thu ',i,': ');readln(a[i]); 
      end;
   for i:=1 to n-m+1 do 
      begin
         s:=0;
         for j:=i to i+m-1 do 
            s:=s+a[j];
         If s>max then max:=s;
      end;
   writeln(max);
readln
end.   

Thảo luận

-- uses crt; var i,j,s,n,m,max,vt:longint; a:array[1..10000]of longint; begin clrscr; write('Nhap n,m: ');readln(n,m); for i:=1 to n do begin write('Nhap phan tu thu ',i,': ');readln(a[i]); end; for i:=1 to n-m+1 do ... xem thêm
-- uses crt; var i,n,m,max,vt:longint; a:array[1..10000]of longint; function s(i:longint):longint; var j:longint; begin s:=0; for j:=i to i+m-1 do s:=s+a[j]; end; begin clrscr; write('Nhap n,m: ');readln(n,m); for i:=1 to n do ... xem thêm
-- rồi nha
-- bạn cho mình hỏi cái cuối giải thích giúp mình đoạn này với for i:=1 to n-m+1 do If s(i)>max then begin vt:=i; max:=s(i); end; for i:=vt to vt+m-1 do write(a[i],' ');
-- s:=0; đặt tổng bằng 0 for j:=i to i+m-1 do chạy từ i đến i+m-1 (Vd là i=3 mà m=2 thì sẽ chạy từ 3 đến 4) s:=s+a[j]; tính tổng If s>max then begin vt:=i; max:=s; end; So sánh tổng với ma, đặt vt là i. for i:=vt to vt+m-1 do write(a[i],' '); Xuất đọn tìm... xem thêm
-- bạn ơi nếu bài toán chỉ là tìm dãy con liên tiếp có tổng lớn nhất của dãy thì sao
-- Ý bạn là sao nhỉ?
-- Bài này là bài đề bạn mà.

Lời giải 2 :

uses crt;
var a:array[1..1000] of longint;
    i,j,n,m,vt:word;
    t,max:longint;
begin
    clrscr;
    readln(n);
    for i:=1 to n do read(a[i]);
    readln;
    readln(m);
    for i:=1 to n-m+1 do
       begin
           for j:=i to i+m-1 do
              t:=t+a[j];
           if max<t then
              begin
                  max:=t;
                  vt:=i;
              end;
       end;
    for j:=i to i+m-2 do write(a[j],';');
    write(a[i+m-1]);
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ự 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 :))

Copyright © 2021 HOCTAP247