Trang chủ Tin Học Lớp 8 Cho 2 số nguyên X=x1x2.xm và Y=y1y2yn (1m,n100). Yêu cầu:...

Cho 2 số nguyên X=x1x2.xm và Y=y1y2yn (1m,n100). Yêu cầu: Tìm số Z=z1z2..zk(Z nhận được từ X và Y bằng cách xóa đi một số chữ số) lớn nhất. Ví dụ: X=12345;

Câu hỏi :

Cho 2 số nguyên X=x1x2.xm và Y=y1y2yn (1m,n100). Yêu cầu: Tìm số Z=z1z2..zk(Z nhận được từ X và Y bằng cách xóa đi một số chữ số) lớn nhất. Ví dụ: X=12345; Y=435012 Thì Z=45 (nhận được từ X bằng cách xóa đi x1x2x3; nhận được từ Y bằng cách xóa đi y2y4y5y6). Dữ liệu: Vào từ file văn bản so.inp - Dòng thứ nhất là X. - Dòng thứ hai là Y. Kết quả: Ghi ra file văn bản so.out - Nếu không có cách xóa thì ghi -1. - Nếu có cách xóa thì ghi số Z ngay ở dòng đầu tiên. inp out 12345 45 435078

Lời giải 1 :

const       max        =250;
            fi         ='so.inp';
            fo        ='so.out';

var         l          :array[1..max+1,1..max+1]of byte;
            a,b,c      :string;

procedure docf;
var  f    :text;
 begin
    assign(f,fi);
    reset(f);
    readln(f,a);readln(f,b);
    close(f);
 end;

function maxso(x,y,z:byte):byte;
 begin
   if x<y then x:=y;
   if x<z then maxso:=z else maxso:=x;
 end;

procedure lam;
var i,j,k,x,y,m :integer;
    ch          :char;
 begin
   fillchar(l,sizeof(l),0);
   for i:=length(a) downto 1 do
    for j:=length(b) downto 1 do
     l[i,j]:=maxso(l[i+1,j],l[i,j+1],l[i+1,j+1]+ord(a[i]=b[j]));

   m:=0;c:='0';
   for ch:='9'downto '1' do
     begin
       i:=pos(ch,a);j:=pos(ch,b);
       if (i>0)and(j>0)and(l[i,j]>m) then begin c:=ch;m:=l[i,j];end;
     end;
   i:=pos(c,a)+1;j:=pos(c,b)+1;
   for k:=m-1 downto 1 do
     for ch:='9'downto '0' do
       begin
          x:=i;y:=j;
          while (x<=length(a))and(a[x]<>ch) do inc(x);
          while (y<=length(b))and(b[y]<>ch) do inc(y);
          if l[x,y]=k then
            begin
               c:=c+ch;i:=x+1;j:=y+1;
               break;
            end;
       end;
 end;

procedure ghif;
var f     :text;
 begin
    assign(f,fo);
    rewrite(f);
    write(f,c);
    close(f);
 end;

BEGIN
   docf;
   lam;
   ghif;
END.

Thảo luận

-- ủa cậu ơi
-- cậu học mấy cái code phức tạp này từ đâu vậy. cho mik xin chỗ học vs đc ko
-- ôn thi hsg nên cô giáo dạy thôi

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