Trang chủ Tin Học Lớp 9 viết chương trình pascal nhập n phần tử và k...

viết chương trình pascal nhập n phần tử và k từ bàn phím tìm đoạn con liên tiếp sao cho đoạn con đó có phần tử không lớn hơn k và có tổng lớn nhất input: n=5,k

Câu hỏi :

viết chương trình pascal nhập n phần tử và k từ bàn phím tìm đoạn con liên tiếp sao cho đoạn con đó có phần tử không lớn hơn k và có tổng lớn nhất input: n=5,k=3 2 3 -5 6 4 output -5 6 4 giúp mik vs ạ ;-;

Lời giải 1 :

Mình mới làm được cách này, bạn tham khảo

program maxseqk;

var
  n, k1, i, maxS, maxI, maxK : integer;
  { Goi s[i] la tong tu a[1 -> i]. Goi la "mảng tổng tiền tố" }
  a, s : array [0 .. 1000000] of longint;

procedure enter;
  var
    i : longint;
  begin
    read(n, k1);
    for i:=1 to n do read(a[i]);
  end;

procedure prefixSum;
  var
    i : integer;
  begin
    s[0] := 0;
    s[1] := a[1];
    for i:=2 to n do
      s[i] := s[i-1] + a[i];
  end;

procedure solve(k : longint);
  var
    i, mi, mk : integer;
    ms : longint;
  begin
    { Tính mảng tổng tiền tố }
    prefixSum;
    { Ban đầu maxS = tổng từ a[1 -> k] }
    i := 1;
    ms := s[k];
    { Tính max của các phần tử độ dài K }
    for i:=2 to n-k do
      if ms < (s[i+k] - s[i-1]) then
        begin
          { Nếu mS bé hơn tổng thì đặt i thành vị trí bắt đầu tổng lớn hơn }
          ms := s[i+k] - s[i-1];
          mi := i;
          mk := k;
        end;
    if ms > maxS then 
      begin
        maxS := ms;
        maxI := mi;
        maxK := mk;
      end
  end;

begin
  { Nhap n, k, a }
  enter;
  { Giai bai toan }
  for i:=1 to k1 do
    solve(i);
  for i:=maxI to maxI+maxK do
    write(a[i], ' ');
  writeln;
end.

Thảo luận

-- tôi ko bt sao chứ thuật toán của tôi là tìm vị trí k, xong xét 2 đoạn con là đoạn trc k (1,2,..,k-1) và đoạn sau k (k+1,k+2,...n), đoạn nào lớn hơn thì lấy thôi :D

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