Trang chủ Tin Học Lớp 8 Giới hạn thời gian: 1.0 giây Giới hạn bộ nhớ:...

Giới hạn thời gian: 1.0 giây Giới hạn bộ nhớ: 128 megabyte Hùng là một học sinh giỏi, được nhiều bạn mến mộ. Thế nhưng, trong dịp Tết vừa qua, vì mải ăn món mứ

Câu hỏi :

Giới hạn thời gian: 1.0 giây Giới hạn bộ nhớ: 128 megabyte Hùng là một học sinh giỏi, được nhiều bạn mến mộ. Thế nhưng, trong dịp Tết vừa qua, vì mải ăn món mứt dâu ngon tuyệt do mẹ cậu làm, kết quả là bị đau bụng suốt mấy ngày liền, khi cậu ta khỏi bệnh cũng chính là lúc hết Tết. Lúc này Hùng mới sực nhớ ra bài tập Tết mà thầy giao, bình thường đó chỉ là những bài tập cỏn con đối với Hùng, thế nhưng giờ đau bụng như thế này thì đến đọc đề còn không nỗi huống chi là làm :(( Các bạn NTUCoders hãy giúp Hùng giải bài tập để không bị thầy phạt ngày đầu năm nhé. Đề bài như sau: Cho dãy n số nguyên dương a1, a2, a3, .., an Có thể thực hiện thao tác sau đây trên dãy: - Chọn ra hai số bất kì trong dãy - Giảm giá trị số lớn hơn đi một lượng bằng giá trị của số nhỏ hơn Có thể thực hiện số lượng thao tác tùy ý thích sao cho tổng giá trị các phần tử của dãy là nhỏ nhất Input Dòng đầu tiên chứa số nguyên dương n (n

Lời giải 1 :

Bạn tham khảo code này xem được không. Lố thời gian hoài hà.

================================

program Hello;
var m,n,i,d:longint;
    a:array[1..1000000] of int64;
begin
    readln(n);
    m:= 1000000000;
    for i:= 1 to n do
        read(a[i]);       
i:=0;
    while d < n do
        begin
            if i = n then i:=0;
            inc(i);
            if (m < a[i]) and (a[i] - m > 0) then
                if m*(a[i] div m) < a[i] then
                    a[i]:= a[i] - m*(a[i] div m)
                else
                    a[i]:= a[i] - m;
            if m > a[i] then begin m:= a[i]; d:=0; end;
            if m = a[i] then inc(d);
        end;
    writeln(m*n);
end.
    

image

Thảo luận

Lời giải 2 :

#Danmelaptrinh

uses crt;
type tlist = array[1..1000] of longint;
var i,n,k,s:longint; a:tlist;
procedure qsort(var a : tlist);
    procedure sort(l,r: longint);
      var
         i,j,x,y: longint;
      begin
         i:=l;
         j:=r;
         x:=a[(l+r) div 2];
         repeat
           while a[i]<x do
            inc(i);
           while x<a[j] do
            dec(j);
           if not(i>j) then
             begin
                y:=a[i];
                a[i]:=a[j];
                a[j]:=y;
                inc(i);
                j:=j-1;
             end;
         until i>j;
         if l<j then
           sort(l,j);
         if i<r then
           sort(i,r);
      end;
    begin
       sort(1,n);
    end;
begin
clrscr;
   readln(n);
   for i:=1 to n do read(a[i]); 
   repeat 
      qsort(a);
      k:=n; 
      while (k>0)and(a[k]=a[n]) do dec(k);
      while (k<>0)and(a[n]>a[k]) do a[n]:=a[n]-a[k];
      s:=0;
      for i:=1 to n do s:=s+a[i];
   until k=0;   
   writeln(s);
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