Trang chủ Tin Học Lớp 8 Cho dãy số gồm n số tự nhiên a1, a2,...

Cho dãy số gồm n số tự nhiên a1, a2, ... , an (1 nhỏ hơn bằng i nhỏ hơn bằn n < 1000, a1 <10000). Dãy con của một dãy số là dãy có được sau khi loại bớt một số

Câu hỏi :

Cho dãy số gồm n số tự nhiên a1, a2, ... , an (1 nhỏ hơn bằng i nhỏ hơn bằn n

image

Lời giải 1 :

const  fi='daycon.inp';
       fo='daycon.out';
       maxn=round(1e5)+5;
var     n,s,i,j,sum,k,dem,tong:longint;
        a,dem: array [1..maxn] of longint;
procedure nhap;
var i:longint;
begin
        assign(input,fi);
        reset(input);
        readln(n,m);
        for i:=1 to n do
        readln(a[i]);
        close(input);
end;
type
     tlist = array[1..max] of longint;
procedure qsortAB(var a,b : tlist);
    procedure sort(l,r: longint);
      var
         i,j,x,y: longint;
      begin
         i:=l;
         j:=r;
         x:=a[(l+r) div 2];
         while(i<=j) do
           begin
                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;
                        y:=b[i]; b[i]:=b[j]; b[j]:=y;
                        inc(i);
                        j:=j-1;
                    end;
            end;
         if l<j then
           sort(l,j);
         if i<r then
           sort(i,r);
      end;

    begin
       sort(1,max);
    end;

procedure xuly;
var c:longint;
begin

                            for i:=1 to n do
                        begin
                                sum:=i;
                                for j := i+1 to n-1 do
                                        begin
                                                if (sum<m) then sum:=sum+a[j]
                                                else if (sum>m) then begin sum :=0; break; end
                                                else if (sum = m) then begin k:=k+1; a[k]:=a[j];  break; end;
                                        end;
                        end;
end;
procedure xuat;
begin
        assign(output,fo);
        rewrite(output);
        if k=0 then write(-1);

        for i:=1 to k do
                begin
                        tong:=0;
                        while tong<m do
                                begin
                                        dec(a[i]);
                                        tong:=tong+a[i];

                                        write(i);                                     
                                end;
                end;

        write(dem);
        close(output);
end;
begin
        nhap;
        xuly;
        xuat;
end.

Thảo luận

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

Copyright © 2021 HOCTAP247